两个特点
(1)对象的状态不受外界影响
解释:以异步操作ajax和setTimeout为例,服务端什么时给接口前端根本控制不了,所以不受外界影响。promise里面接受的是一个匿名的函数作为promise的参数,并且函数自身有作用域的外部无法访问里面的东西,所以就更不受外界影响了,个人理解
(2)一旦状态改变,就不会再变,任何时候都可以得到这个结果,Ajax有结果返回,那你对一个接口发起一次ajax请求,肯定就只有一个结果,再你发送下一次ajax请求之前,肯定就不会再变了。多个promise对象执行一波操作的时候有的成功了成功了就叫resolved,失败的话就叫rejected,但无论成功还是失败,它们都完成了(fulfilled)。
但对于单个promisefulfilled和resolved基本没什么区别
但对多个比如(allSettled())
两个缺点:
1.无法取消promise,例如ajax请求,对与Ajax请求你发了就是发了没有get、post请求发一半说不发了的事
2.如果不设置回调函数,promise内部抛出错误,不会反应到外部。
设置了回调就是,有结果了就回调
3.处于pending状态时,无法得知目前进展到哪个阶段(刚刚开始还是即将完成)
这个也很好理解,你发送了get、post请求后服务端那边的事,除非建立了长连接,不然不可能知道现在进行到哪一步了,因为http是一个无状态的协议,你连接之后他就断了
1.promise对象就是个容器,里面写的是未来执行的东西,比如setTimeout,它会再几秒后才会执行结束
又比如ajax请求它会在未来一段时间才会结束,多少时间不确定
2.从结构来看promise支持链式调用,所以promise对象它将多个相互嵌套的回调拉长拉平成一个队列,然后按照你希望的顺序去执行
//简单的demo实例
new Promise((resolve,reject)=>{
setTimeout(()=>{
resolve('我是xxx,xxx123')
},2000)
}).then((data)=>{
//成功
console.log(data);
},(err)=>{
//失败
console.log(err)
})