对Promise逐步认知
一
Promise 的 then 、catch、finally都会返回自身Promise的引用
console.log('then',Promise.resolve().then()); console.log('catch',Promise.resolve().catch()); console.log('finally',Promise.resolve().finally());
这一点对封装基础逻辑的ajax请求很有帮助
二
下面两种写法有啥区别
Promise.reject().then( (res) => {}, (rej) => { console.log("发生错误"); }, ); Promise.reject() .then((res) => {}) .catch((rej) => { console.log("发生错误"); });
Promise.prototype.catch方法是.then(null, rejection)或者.then(undefined, rejection)的别名,用于指定发生错误时的回调函数
尽管都会输出=>发生错误,但是第二种方法还会捕获then 里面的错误
Promise.resolve().then( (res) => { throw new Error("抛出异常"); }, (rej) => { console.log("发生错误"); }, ); Promise.resolve() .then((res) => { throw new Error("抛出异常"); }) .catch((rej) => { console.log("发生错误"); });结果为:

三
axios 实现了Promise 规范race 表示 哪个结果取得的快,就返回那个结果,不论结果本身是成功状态还是失败状态。
结合一下:
Promise.race([ axios.post("/test/test/test2"), axios.post("/test/test/test1"), ]).then((r1) => { console.log("res", r1); });我之前一直以为race 表示哪个成功用哪个,开发时候没涉及到这种场景,竟然就这么过来了…
说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » 对Promise逐步认知
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » 对Promise逐步认知