Promise永远不会失败或成功两次或更多次。这只能发生一次。
一个Promise既不能从成功变成失败,也不能从失败变成成功。如果Promise成功还是失败,并且过了一段时间,如果添加了任何成功/失败回调,则无论事件发生在何处,都将调用正确的回调。
pending:待处理的承诺尚未被拒绝或尚未实现。
fulfilled:相关的诺言操作已成功完成。
rejected:相关的诺言操作未能实现。
settled:该操作已完成或被拒绝。
除非当前未完成js事件循环的执行(成功或失败),否则永远不会在其之前调用回调。
即使存在带有then()的回调,但是只有在完全执行异步操作之后,才会调用它们。
如果通过多次调用then()可以包含多个回调,则每个回调将按链执行,即按照插入的顺序一个接一个地执行。
方法名称 | 摘要 |
Promise.resolve(promise) | 仅当promise.constructor == Promise时,此方法才会返回promise。 |
Promise.resolve(thenable) | 从thenable包含then()作出新的承诺。 |
Promise.resolve(obj) | 做出对一个对象的承诺。 |
Promise.reject(obj) | 对对象做出承诺拒绝。 |
Promise.all(array) | 当数组中的每个项目都完成时做出承诺,或者在数组中的每个项目都没有完成时拒绝。 |
Promise.race(array) | 如果数组中的任何项目被立即满足,它将解决承诺;或者,如果任何项目被立即拒绝,则将拒绝承诺。 |
构造函数 | 说明 |
new Promise(function(resolve, reject){}); | 在这里,resolve(thenable)表示将使用then()解决承诺。 Resolve(obj)表示将通过对象实现承诺。 Reject(obj)表示被对象拒绝的承诺。 |
<html>
<head>
<h2> Javascript Promise</h2>
</br> </head>
<body>
<script>
var p=new Promise(function(resolve, reject){
var x= 2+3;
if(x==5)
resolve(" executed and resolved successfully");
else
reject("rejected");
});
p.then(function(fromResolve){
document.write("Promise is"+fromResolve);
}).catch(function(fromReject){
document.write("Promise is "+fromReject);
});
</script>
</body>
</html>
Resolve:成功执行诺言后,将调用resolve参数,从而提供结果。
Reject::当承诺被拒绝时,将拒绝参数被调用,从而导致错误。
处理异步操作的更好选择。
提供简单的错误处理和更好的代码可读性。