1.Promise的汉译是诺言
我突然明白了promise的意义,就是一个方法、一个js乃至一个页面的后续js代码的执行,都依赖于一个异步返回的数据,那么接下来所有的js代码都可以放在promise的then里面,链式调用,清晰了点吧~。其实await也可以实现这样的方式,但是应该promise更好一点。
2.怎么用Promise
因为一直被各种插件框架封装的ajax混淆,所以一直不理解promise,因为他们都有自己实现promise的方法,抛去ajax的思维,我们可以使用setTimeout来做实验
promise构造函数,resolve和reject是早就封装在构造函数里面的方法。new的时候写上就行了。
promise demo1上面的demo中,test函数会返回一个promise对象,这个对象啊,接收一个函数作为参数,作为参数的函数还接受两个参数,这个两个参数是两个方法,resolve方法可以把promise的状态从pedding改变成resolved,reject方法可以把promise的状态从pedding改变成rejected。promise的只能改变一次,一旦变成resolved/rejected。将不会在改变。
下面的链式调用,如果promise对象使用了resolve方法,那么调用的时候,就走then回调。否则走catch错误捕获回调。
其实到这里,就觉得promise就是个回调函数而已。跟jquery里面的ajax请求成功执行的success函数一样。但是promise厉害的地方就是多重回调。链式回调。
改变promise的状态,并不会终结后面代码的执行,但是resolve或者reject之后,promise的任务就完成了,后续操作最好放在then的回调里。
3.链式回调
promise的链式调用链式回调就是同步的,一定要等到上一个promise的状态改变了,才能立即执行下一个promise。
我也不知道一般用到哪些地方,因为三方插件都有自己的promise的实现。这个我暂时也不知道用在哪儿。后续再进行补充吧。
网友评论