• 技术文章 >web前端 >js教程

    js中promise实例解析

    小云云小云云2018-02-05 10:00:45原创1361
    大家都知道nodejs很快,为什么会这么快呢,原因就是node采用异步回调的方式来处理需要等待的事件,使得代码会继续往下执行不用在某个地方等待着。但是也有一个不好的地方,当我们有很多回调的时候,比如这个回调执行完需要去执行下个回调,然后接着再执行下个回调,这样就会造成层层嵌套,代码不清晰,很容易进入“回调监狱”,就容易造成下边的例子:

    async(1, function(value){
     async(value, function(value){
     async(value, function(value){
      async(value, function(value){
      async(value, function(value){
       async(value, final);
      });
      });
     });
     });
    });

    这样的写法会让人崩溃,那么有什么办法可以解决这个问题呢,或者有其他别的写法吗?答案是有的,es6新出的promise对象已经es7的async await都可以解决这个问题,当然这里先介绍promise对象,es7的async await将在后边的文章中分享。下边将来介绍Promise对象。

    二、简介

    Promise,他是一个对象,是用来处理异步操作的,可以让我们写异步调用的时候写起来更加优雅,更加美观便于阅读。顾名思义为承诺、许诺的意思,意思是使用了Promise之后他肯定会给我们答复,无论成功或者失败都会给我们一个答复,所以我们就不用担心他跑了哈哈。所以,Promise有三种状态:pending(进行中),resolved(完成),rejected(失败)。只有异步返回的结构可以改变其状态。所以,promise的过程一般只有两种:pending->resolved或者pending->rejected。

    promise对象还有一个比较常用的then方法,用来执行回调函数,then方法接受两个参数,第一个是成功的resolved的回调,另一个是失败rejected的回调,第二个失败的回调参数可选。并且then方法里也可以返回promise对象,这样就可以链式调用了。接下来上代码:

    var Pro = function (time) {
       //返回一个Promise对象
       return new Promise(function (resolve, reject) {
        console.log('123');
        //模拟接口调用
        setTimeout(function () {
         //这里告诉Promise 成功了,然后去执行then方法的第一个函数
         resolve('成功返回');
        }, time);
       })
      };
      (function(){
       console.log('start');
       Pro(3000)
       .then(function(data){
        console.log(data);
        return Pro(5000);})
       .then(function(data){
        console.log(data);
        console.log('end');
       })
      })();

    上边代码中,定义了一个Pro变量,然后把一个匿名函数赋给他,函数返回一个Promise对象,然后对象里边接收一个函数,分别把resolve跟reject方法当参数传进去,用setTimeOut来模拟异步请求,当执行resolve方法后就会调用then方法的一个函数。结果如下:

    三、Promise 的api 

    1、Promise.resolve()
    2、Promise.reject()
    3、Promise.prototype.then()
    4、Promise.prototype.catch()
    5、Promise.all() // 所有的都有完成,相当于 且
    6、Promise.race() // 完成一个即可,相当于 或

    1、Promise.resolve()的作用将现有对象转为Promise对象resolvedl;Promise.resolve('test')==new Promise(resolve=>resolve('test'))

    2、Promise.reject()也是返回一个Promise对象,状态为rejected;

    3、then方法上边已经做介绍,这里就不再介绍。

    4、catch():发生错误的回调函数。

    5、Promise.all()适合用于所有的结果都完成了才去执行then()成功的操作。举个例子:

    let p1 =new Promise(function(resolve,reject){
       resolve(1);
      });
      let p2 = new Promise(function(resolve,reject){
       resolve(2);
      });
      let p3 = new Promise(function(resolve,reject){
       resolve(3);
      });
      Promise.all([p1, p2, p3]).then(function (results) {
       console.log('success:'+results);
      }).catch(function(r){
       console.log("error");
       console.log(r);
      });

    最后输出:

    6、Promise.race()的作用也是同时执行多个实例,只要有一个实例改变状态,Promise就改为那个实例所改变的状态;

    四、例子

    var Pro = function () {
       //返回一个Promise对象
       return new Promise(function (resolve, reject) {
        //模拟接口调用
        setTimeout(function () {
         resolve(true);
        }, 1000);
       })
      };
      var Pro2 = function () {
       //返回一个Promise对象
       return new Promise(function (resolve, reject) {
        //模拟接口调用
        setTimeout(function () {
         resolve('Pro2成功执行');
        }, 1000);
       })
      };
      
      Pro().then(function(data){
       var val = data;
       console.log(val)
       if (val) {
        console.log(1111)
        return Pro2()
       }
       
      }).then(function(data1){
       console.log(data1)
      })

    输出:

    这样就可以用then方法可以实现链式调用了。

    相关推荐:

    ES6 Promise 扩展always方法实例详解

    jQuery的Promise如何正确使用

    promsie.all和promise顺序执行详解

    以上就是js中promise实例解析的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:javascript promise 实例
    上一篇:JS删除数组里的某个元素实例代码 下一篇:JS百度搜索接口及链接功能的实现代码
    php培训_php实战培训【立即报名】-php中文网第20期

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• JavaScript弱映射与弱集合知识详解• 一篇搞定JavaScript DOM详细操作• 深入聊聊JavaScript• JavaScript迭代器知识点总结• javascript web页面刷新的方法收集_javascript技巧
    1/1

    PHP中文网