标签:参数 生成 space return 异步执行 mis ror 多个 new
let p = new Promise(function(resolve, reject) { console.log(‘11‘); }); p.then(function() { console.log(‘22.‘); }); console.log(‘Hi!‘);//11 Hi! let p2 = new Promise(function(resolve, reject) { console.log(‘11‘); resolve(); }); p2.then(function() { console.log(‘22.‘); }); console.log(‘Hi!‘);//11 Hi! 22.
Promise的构造函数接收一个参数是函数,并且传入两个参数:resolve,reject,初步不准确的理解分别表示异步操作执行成功后的回调函数和异步操作执行失败的回调函数
function runAsync(){ var p = new Promise(function(resolve, reject){ //做一些异步操作 resolve(‘1‘); console.log(‘2‘); }); return p; } runAsync().then(function(data){ console.log(data); });//2 1
reject用法:
function getNumber(){ var p = new Promise(function(resolve, reject){ //做一些异步操作 setTimeout(function(){ var num = Math.ceil(Math.random()*10); //生成1-10的随机数 if(num<=5){ resolve(num); } else{ reject(‘数字太大了‘); } }, 2000); }); return p; } getNumber().then( function(data){ console.log(‘resolved‘); console.log(data); }, function(reason, data){ console.log(‘rejected‘); console.log(reason); } ); //rejected 数字太大了 //resolved 1
catch用法:和then的第二个参数一样,用来指定reject的回调,例如:
getNumber() .then(function(data){ console.log(‘resolved‘); console.log(data); console.log(somedata); //此处的somedata未定义 }) .catch(function(reason){ console.log(‘rejected‘); console.log(reason); });
如果不用catch,代码运行到未定义的somedata那里直接报错不往下运行了,但是用了catch,会得到下面的结果resolved 3 rejected ReferenceError: somedata is not defined at <anonymous>:5:17
function runAsync1(){ var p = new Promise(function(resolve, reject){ //做一些异步操作 setTimeout(function(){ console.log(‘异步任务1执行完成‘); resolve(‘随便什么数据1‘); }, 1000); }); return p; } function runAsync2(){ var p = new Promise(function(resolve, reject){ //做一些异步操作 setTimeout(function(){ console.log(‘异步任务2执行完成‘); resolve(‘随便什么数据2‘); }, 2000); }); return p; } Promise.all([runAsync1(),runAsync2()]).then(function(results){ console.log(results); })
//异步任务1执行完成 异步任务2执行完成 ["随便什么数据1", "随便什么数据2"]
只有runAsync1和runAsync2的状态都变成fulfilled,最后才能变成fulfilled状态执行最后的回调,如果有一个rejected,最后就会变成rejected,此时第一个被rejected的实例返回值传给回调函数
Promise.race([runAsync1(),runAsync2()]).then(function(results){ console.log(results); }) //异步任务1执行完成 随便什么数据1 异步任务2执行完成
标签:参数 生成 space return 异步执行 mis ror 多个 new
原文地址:https://www.cnblogs.com/luluyang/p/9855424.html