作家
登录

30分钟,让你彻底明白Promise原理

作者: 来源: 2017-06-08 10:02:44 阅读 我要评论

  •  
  •   
  •  
  • getUserId().then(function(id) { 
  •  
  •     //一些处理 
  •  
  • }, function(error) { 
  •  
  •     console.log(error) 
  •  
  • })  
  • 有了之前处理fulfilled状况的经验,支掉足误处理变得很轻易,只须要在注册回调、处理状况变革上都要参加新的逻辑:

    1. function Promise(fn) { 
    2.  
    3.     var state = 'pending'
    4.  
    5.         value = null
    6.  
    7.         callbacks = []; 
    8.  
    9.   
    10.  
    11.     this.then = function (onFulfilled, onRejected) { 
    12.  
    13.         return new Promise(function (resolve, reject) { 
    14.  
    15.             handle({ 
    16.  
    17.                 onFulfilled: onFulfilled || null
    18.  
    19.                 onRejected: onRejected || null
    20.  
    21.                 resolve: resolve, 
    22.  
    23.                 reject: reject 
    24.  
    25.             }); 
    26.  
    27.         }); 
    28.  
    29.     }; 
    30.  
    31.   
    32.  
    33.     function handle(callback) { 
    34.  
    35.         if (state === 'pending') { 
    36.  
    37.             callbacks.push(callback); 
    38.  
    39.             return
    40.  
    41.         } 
    42.  
    43.   
    44.  
    45.         var cb = state === 'fulfilled' ? callback.onFulfilled : callback.onRejected, 
    46.  
    47.             ret; 
    48.  

    49.   推荐阅读

        2017年上半年重大黑客事件盘点

      16. 美国法律论坛71万账户泄漏,涉国度安然局、FBI等本年4月,达拉斯紧急警备孀体系被黑客入侵。导致该城市的156个紧急戒备器被激活,警笛声持续一个小时,激发市平易近惊恐。 在以前的201>>>详细阅读


      本文标题:30分钟,让你彻底明白Promise原理

      地址:http://www.17bianji.com/lsqh/35631.html

    关键词: 探索发现

    乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

    网友点评
    自媒体专栏

    评论

    热度

    精彩导读
    栏目ID=71的表不存在(操作类型=0)