对Promise逐步认知

作者 : 开心源码 本文共887个字,预计阅读时间需要3分钟 发布时间: 2022-05-13 共201人阅读

Promisethencatchfinally都会返回自身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逐步认知

发表回复