Promise.resolve()
Promise.resolve(value)方法返回一个以给定值解析后的Promise对象。如果该值为promise,返回这个promise;如果这个值是thenable(即带有"then" 方法),返回的promise会“跟随”这个thenable的对象,采用它的最终状态;否则返回的promise将以此值完成。此函数将类promise对象的多层嵌套展平。
警告:
不要在解析为自身的thenable上调用Promise.resolve。这将导致无限递归,因为它试图展平无限嵌套的promise。一个例子是将它与Angular中的异步管道一起使用。
语法
Promise.resolve(value);
参数
value将被Promise对象解析的参数,也可以是一个Promise对象,或者是一个thenable。
返回值
返回一个解析过带着给定值的Promise对象,如果参数是一个Promise对象,则直接返回这个Promise对象。
描述
静态方法 Promise.resolve返回一个解析过的Promise对象。
示例
使用静态Promise.resolve方法
1 2 3 4 5
| Promise.resolve("Success").then(function(value) { console.log(value); }, function(value) { });
|
resolve一个数组
1 2 3 4
| var p = Promise.resolve([1,2,3]); p.then(function(v) { console.log(v[0]); });
|
resolve另一个promise
1 2 3 4 5 6 7 8 9 10 11 12
| var original = Promise.resolve(33); var cast = Promise.resolve(original); cast.then(function(value) { console.log('value: ' + value); }); console.log('original === cast ? ' + (original === cast));
|
日志顺序颠倒其实是由于异步地调用then方法。
resolve thenable 并抛出错误
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39
| var p1 = Promise.resolve({ then: function(onFulfill, onReject) { onFulfill("fulfilled!"); } }); console.log(p1 instanceof Promise)
p1.then(function(v) { console.log(v); }, function(e) { });
var thenable = { then: function(resolve) { throw new TypeError("Throwing"); resolve("Resolving"); }};
var p2 = Promise.resolve(thenable); p2.then(function(v) { }, function(e) { console.log(e); });
var thenable = { then: function(resolve) { resolve("Resolving"); throw new TypeError("Throwing"); }};
var p3 = Promise.resolve(thenable); p3.then(function(v) { console.log(v); }, function(e) { });
|