- A+
所属分类:Web前端
Promise
var runAsync = () => { var p = new Promise(function(resolve, reject) { //做一些异步操作 setTimeout(function() { console.log('执行完成'); resolve('随便什么数据'); }, 2000); }); return p; } runAsync().then(function(data) { console.log(data); return new Promise(function(resolve, reject) { resolve(1, 2, 3, 4) }) }).then(function(data) { console.log(data); return "84651" }).then(function(data) { console.log(data); });
- Promise -对象,接收函数作为参数,该函数两个参数分别是 resolve和reject。(resolve reject 函数)
- .then()方法返回新的Promise实例
- .then()方法中的回调函数/function(data){}/完成后,会将返回结果作为参数,传入下一级的回调函数
- 如果/function(data){}/ 返回Promise对象 这时候下一个回调函数,就会等待该Promise对象的状态发生变化,才会被调用. //等待回调
- 即下一个.then()相当于该回调函数返回Promise对象的.then()
- 如果返回参数: 将返回结果作为参数传入下一个回调函数/function(data){}/
- 该then方法返回的新的promise的状态会变成fulfilled(同时成功的回调函数也会被调用)。//立即执行
- 如果/function(data){}/ 返回Promise对象 这时候下一个回调函数,就会等待该Promise对象的状态发生变化,才会被调用. //等待回调