解释一下这段代码的执行

解释一下这段代码的执行

jsonp(url,params,{
 param: 'callback'
}).then(res => {
 if (res.code === '200'){
   return res;
 }
 throw new Error('没有成功获取到数据!');
}).catch(err => {
 if (err){
   console.log(err);
 }
}).then(data = > {
 return new Promise(resolve => {
   setTimeout(() => {
     resolve(data);
   },1000);
 })
});


什么时候走catch 什么时候走then

正在回答 回答被采纳积分+1

登陆购买课程后可参与讨论,去登陆

3回答
好帮手慕星星 2019-09-07 17:22:17

同学你好,

1、export default 是默认导出,没有函数名字也可以:

http://img1.sycdn.imooc.com//climg/5d7373db00013c3f06610296.jpg

导入的时候变量就会接受导出的函数,可以输出jsonp看看:

http://img1.sycdn.imooc.com//climg/5d7375da000146e003720044.jpg

http://img1.sycdn.imooc.com//climg/5d7376080001d83207040123.jpg

用的时候直接用jsonp即可,就是这个函数:

http://img1.sycdn.imooc.com//climg/5d7376200001496505960092.jpg

2、promise封装一层是为了使用then和catch方法,在recommend.vue中引入home.js,调用方法:

http://img1.sycdn.imooc.com//climg/5d7376b50001e51b06830362.jpg

后面使用了then。

自己可以再理解下,祝学习愉快!

樱桃小胖子 2019-09-06 19:38:04

成功执行then,不成功执行catch,包装一层promise是因为封装的jsonp.js文件中,函数返回的是一个promise实例哦

希望可以帮到你!

  • 提问者 JJJustin #1
    export default (url,data,options) => { url += (url.indexOf('?') < 0 ? '?' : '&') + parseParm(data); return new Promise((resolve, reject) => { jsonp(url,options,(err,data) => { if (err){ reject(err); }else{ resolve(data); } }) }) }; 问题1:为什么这个函数没有名字 其他地方还可以用jsonp()来调用 问题2:用promise封装一层是为了使用then和catch方法吗
    2019-09-06 21:03:29
提问者 JJJustin 2019-09-06 16:19:08

接口成功 走then 包装一层promise返回 接口失败走catch?

包装一层promise的意义何在呢

问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星
请稍等 ...
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师