• 异步编程之Javascript Promises 规范介绍


    什么是 Promises

    Promises是一种关于异步编程的规范。目的是将异步处理对象和处理规则进行规范化。为异步编程提供统一接口。

     

    传统的回调函数

    说到JavaScript的异步编程处理,通常我们会想到回调函数,如以下的代码:

    getFileAsync("1.txt", function(error, result){
    
         if(error){
    
             throw error;
    
         }
    
        // 取得成功时的处理
    
    });
    

      

    上面的代码定义了一个获取文件内容的函数,读取完毕后回调用传入的回调函数。对于以下的场景:

          - 读取文件 1.txt 的内容。其内容也是一个文件地址。我们称为 2.txt

          - 读取文件 2.txt 的内容。其内容还是一个文件地址。我们称为 3.txt

          - 读取文件 3.txt 的内容

     

    使用回调函数的代码例如以下:

     

    getFileAsync(“1.txt", function(error1, result1){
    
         if(error1){
    
              throw error1;
    
         }
    
         getFileAsync(result1, function(error2, result2){    
    
              if(error1){
    
                   throw error1;
    
              }
    
              getFileAsync(result2, function(error3, result3){
    
                   console.log(result3);
    
              });
    
         });
    
    });
    

     

      

    这就是所谓的回调金字塔。回调函数嵌套非常深。代码非常不好看。也不easy阅读。而Promise正是碾平异步回调的解决方式。 

     

    Promises 规范

    Promises/A(http://wiki.commonjs.org/wiki/Promises/A)是由CommonJS组织制定的异步模式编程规范,提供了一个在程序中描写叙述延时(或将来)概念的解决方式。基本的思想是运行一个异步方法的时候。不堵塞应用程序。返回一个Promise对象。

     

    Promises/A+(https://promisesaplus.com/)规范是对Promises/A规范的补充和改动。

     

    Promise对象有三种状态:初始状态(pending)、成功(fulfilled)和失败(rejected),当中pending为初始状态,fulfilled和rejected为结束状态。状态转换关系为:pending->fulfilled,pending->rejected。 promise对象从Pending转换为FulfilledRejected之后。 这个promise对象的状态就不会再发生不论什么变化。例如以下图:

     

     

    Promise是一个拥有 then 方法的对象,then接口用于监听一个Promise的不同状态。

     

    then(fulfilledHandler, errorHandler, progressHandler)。

    加入fulfilledHandler、errorHandler和progressHandler后,promise对象就构成了。

    fulfilledHandler是在promise被装载数据的时候调用。errorHandler在promise失败的时候调用,progressHandler则在progress事件触发的时候调用。

     

    var promise = getAsyncPromise("fileA.txt");
    
    promise.then(function(result){
    
         // 获取文件内容成功时的处理
    
    }, function(error){
    
         // 获取文件内容失败时的处理
    
    }); 
    

      


    Promises 链式调用
     

    then方法在fulfilledHandler或者errorHandler回调完毕之后,会返回一个新的promise对象。而不是原来的Promise对象,这样一来。promise操作就行形成链式调用。

     

    var promise = new Promise(function (resolve) {
    
        resolve(100);
    
    });
    
      
    
    promise.then(function(value) {
    
         return value *2;
    
    }).then(function(value) {
    
         return value *2;
    
    }).then(function(value) {
    
         console.log(value); // => 100 * 2 * 2
    
    }); 
    

     

      

    Promises 错误处理 

    then()函数接收两个回调函数作为參数。

    第二个回调函数在Promise变为rejected时被触发的函数。

    Promise还提供了一个catch()函数来处理Promise的rejected状态。

    看以下的代码:

    promise.then(fucntion(result){
    
        console.log('Got data!',relust);
    
    }).catch(function(error){
    
        console.log('Error occurred!',error);
    
    });
    

      

     上面的代码事实上等价于:

    promise.then(function(result){
    
        console.log('Got data',result);
    
    },function(error){
    
        console.log('Error occurred!',error);
    
    }); 
    

      


    浏览器支持:
     

    Promises 如今已经是JavaScript标准的一部分了, 差点儿所有的浏览器已经实现了Promises API。浏览器兼容性例如以下:

     

     

    本文简要的介绍了Promises的基础知识,希望我们我们可以更好的使用Promises,更轻松的编写代码。

  • 相关阅读:
    android studio下生成jni头文件
    ndk编译android的lame库
    hbuilder在android手机里用chrome调试,只显示了设备名称,却没有inspect按钮
    mac下升级terminal/终端的subversion版本方法
    mac下编译optool方法
    ubuntu16.04 64位server安装php7
    Ubuntu系统启用Apache Mod_rewrite模块
    cakephp之查询
    Ubuntu 中搭建 LAMP 及 php 开发工具
    [JS]视频总结-第四部分_JavaScript案例-定时器的使用
  • 原文地址:https://www.cnblogs.com/llguanli/p/8650357.html
Copyright © 2020-2023  润新知