大保剑:Promise的有趣体验

对于ES6的Promise到如今已经跨过了ES7的一个版本了,下面介绍的这些玩意,看了千万要忍住了,如果你一眼看了感觉"so easy",那么恭喜你,收下我这个小菜鸟吧😄!
看!👇的代码,为了看的更加清楚,这里不做异常处理了!
javascript 复制代码
// 首先先定义两个变量式函数吧!
let test1 = () => {
    return new Promise((resolve, reject) => {
        resolve('test1...');
    })
}

let test2 = () => {
    return 'test2...';
}
下面开始忽悠...

这里先对Promise的then(onFulfilled, onRejected)中的两个参数的做一个了解,这两个参数都是可选的:(ps: 这里不对onRejected做梳理)。

  • 如果onFulfilled不是函数,就会忽略该参数
  • 如果onFulfilled是函数,就会将onFulfilled中的返回值作为下一个then函数的参数使用
Fun1⬇️
javascript 复制代码
test1().then(() => {
    return test2();
}).then((val) => {
    console.log(val);
    console.log('---->1');
})

######这个结果为什么会这样呢?

这是因为在第一个then函数中有返回值(return 'test2'),作为第二个then函数的参数传递,所以...嗯!

Fun2⬇️
javascript 复制代码
test1().then(() => {
    test2();
}).then((val) => {
    console.log(val);
    console.log('----2');
})
这个结果为什么会这样呢?

这是因为第一个then()函数中没有返回值,所以默认当作undefined处理,结果就是这样了...

Fun3⬇️
javascript 复制代码
test1().then(test2()).then((val) => {
    console.log(val);
    console.log('------3');
})
这个结果为什么会这样呢?

这是因为第一个then()函数里根本就不是一个函数,而是一个字符串,看上面的提前解读,不是函数的时候就会被忽略,自动寻找上一个then()的返回值,这里使用的是resolve()里的值,即'test1...'

Fun4⬇️
javascript 复制代码
test1().then(test2).then((val) => {
    console.log(val);
    console.log('------4');
})
这个结果为什么会这样呢?

这是因为第一个then()函数里的test2作为回调函数传递了进去,进而该then()函数就会有返回值了(return 'test2...'),这样就可以作为第二个then函数的参数传递进去了...gg!

最后,附上一张图,可能会更加直观。

END!

相关推荐
灵感__idea2 小时前
Hello 算法:贪心的世界
前端·javascript·算法
killerbasd5 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
橘子编程6 小时前
JavaScript与TypeScript终极指南
javascript·ubuntu·typescript
叫我一声阿雷吧6 小时前
JS 入门通关手册(45):浏览器渲染原理与重绘重排(性能优化核心,面试必考
javascript·前端面试·前端性能优化·浏览器渲染·浏览器渲染原理,重排重绘·reflow·repaint
大家的林语冰7 小时前
《前端周刊》尤大开源 Vite+ 全家桶,前端工业革命启动;尤大爆料 Void 云服务新产品,Vite 进军全栈开发;ECMA 源码映射规范......
前端·javascript·vue.js
jiayong237 小时前
第 8 课:开始引入组合式函数
前端·javascript·学习
天若有情6738 小时前
【C++原创开源】formort.h:一行头文件,实现比JS模板字符串更爽的链式拼接+响应式变量
开发语言·javascript·c++·git·github·开源项目·模版字符串
yuki_uix8 小时前
重排、重绘与合成——浏览器渲染性能的底层逻辑
前端·javascript·面试
止观止9 小时前
拥抱 ESNext:从 TC39 提案到生产环境中的现代 JS
开发语言·javascript·ecmascript·esnext
时寒的笔记9 小时前
js逆向7_案例惠nong网
android·开发语言·javascript