Promise的链式操作

最简单的Promise例子

function timeout(ms){
     return new Promise(function(resolve){
         setTimeout(resolve, ms); 
     })
}
timeout(1000).then(function(){
     console.log("done");
})
Promise 和 回调 不同在于:
  • Promise简化了代码写法,有链式操作
  • 可以catch所有代理异步操作的错误,callback只能知道自己的错误
链式操作
简化了多层回调嵌套,避免“回调地狱 ”
所谓回调地狱,一层层嵌套,不利于阅读和维护:
setTimeout(function (name) {
  var catList = name + ',';
  setTimeout(function (name) {
    catList += name + ',';
    setTimeout(function (name) {
      catList += name + ',';
      setTimeout(function (name) {
        catList += name + ',';
        setTimeout(function (name) {
          catList += name;
          console.log(catList);
        }, 1, 'Lion');
      }, 1, 'Snow Leopard');
    }, 1, 'Lynx');
  }, 1, 'Jaguar');}, 1, 'Panther');

现在要一次执行p1、p2、p3、p4,用then函数,链式操作,

        p1().then(function () {
            console.log("我是回调");
            return p2();
        }).then(function () {
            console.log("我是回调");
            return p3();
        }).then(function () {
            console.log("我是回调");
            return p4();
        });

        var p1 = function(){
            return new Promise(function (resolve, reject) {
                setTimeout(function () {
                    console.log('11111');
                    resolve("p1");
                }, 1000)
            })
        };
        function p2 () {
            return new Promise(function (resolve, reject) {
                setTimeout(function () {
                    console.log('22222');
                    resolve("p2")
                }, 1000)
            })
        }
        function p3 () {
            return new Promise(function (resolve, reject) {
                setTimeout(function () {
                    console.log('33333');
                    resolve("p3");
                }, 1000);
            })
        }
        function p4 () {
            return new Promise(function (resolve, reject) {
                setTimeout(function () {
                    console.log('44444');
                    resolve("p4");
                }, 1000);
            })
        }

 

转载于:https://www.cnblogs.com/hjqbit/p/6883703.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值