promise简介

promise是什么?
从语法上:promise是一个构造函数;
从功能上:promise对象封装一个异步操作,并可以获取其结果。(即将异步步任务转化成同步任务)
promise有什么作用?
promise指定回调函数的方式更加灵活。
步骤:启动异步任务=》返回promise对象=》给promise对象绑定回调函数

promise的特点:
1、对象状态的改变不受外界的影响,仅有异步操作的结果可以决定当前的状态,主要由三个状态,分别是fulfilled(成功),rejected(失败),pending(等待)。

2、一旦状态改变,就不会再变,只有两种状态的改变,从pending到fulfilled和从pending到rejected。状态一旦改变,便不会再变,这时就叫作resolved(定性)。任何时候通过添加回调函数就会得到状态的结果。

promise的优缺点
promise优点:
将异步操作以同步操作的流程表达出来,避免了层层嵌套的回调函数;
此外,提供了promise提供了统一的接口,使得控制异步操作更加容易。
promise缺点:
一旦新建promise便会立即执行,无法中途退出;
当处于pedding状态时,无法知道当前进行到哪一阶段。

promise和回调函数的区别
回调函数:回调函数本身是一个函数,将函数作为参数传入另一个函数,当外部函数执行完成后立即执行回调函数。

前情提要:
js是单线程的。js的主要作用是操作dom,实现用户与界面交互的。
同步与异步:
异步用来存放未来才能结束的事件。
例如
const getList = () => {
setTimeout(() => {
console.log('我执行了!');
}, 2000);
};
console.log('Hello World');
getList();
console.log('哈哈哈');

执行顺序是:
Hello World、哈哈哈、我执行了!(两秒以后执行最后一个)
异步任务后于同步任务执行,通过setTimeout实现。

消息队列:同步任务是主线程执行,此外浏览器还会维护一个消息队列,副线程合起来叫作消息列表。异步任务先存放在消息队列中,等待主线程执行完再执行消息队列中的任务。

事件轮询:副线程中谁先执行,这个选择的过程可以理解为事件轮询。
setTimeout(function() {
console.log('我是定时器!');
})
new Promise(function(resolve) {
console.log('我是promise!');
resolve();
}).then(function() {
console.log('我是then!');
})
console.log('我是主线程!');

执行顺序:
我是promise!(为什么此句先执行?)
我是主线程!
我是then!(异步微任务)
我是定时器!(异步宏任务)

全部评论

相关推荐

09-29 11:19
门头沟学院 Java
点赞 评论 收藏
分享
10-05 11:11
海南大学 Java
投票
理想江南137:感觉挺真诚的 感觉可以试一试
点赞 评论 收藏
分享
点赞 1 评论
分享
牛客网
牛客企业服务