微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Promise

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(同时成功的回调函数也会被调用)。//立即执行

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐