作家
登录

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

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

 (job) { 
  •  
  •         // 对job的处理 
  •  
  •     }); 
  •  
  •   
  •  
  • function getUserJobById(id) { 
  •  
  •     return new Promise(function (resolve) { 
  •  
  •         http.get(baseUrl + id, function(job) { 
  •  
  •             resolve(job); 
  •  
  •         }); 
  •  
  •     }); 
  •  
  •  
  • 这种场景信赖用过promise的人都知道话苄很多,那么类似这种就是所谓的链式Promise。

    链式Promise是指在当前promise达到fulfilled状况后,即开端进行下一?promise(后邻promise)。那么我们若何连接当前promise和后邻promise呢?(这是这里的可贵)。

    其实也不是辣么难,只要在then办法琅绫擎return一个promise就好啦。Promises/A+规范中的2.2.7就是这么说哒(微笑容)~

    下面来看看这段隐蔽玄机的then办法和resolve办法改革代码:

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

    39.   推荐阅读

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

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


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

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

    关键词: 探索发现

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

    网友点评
    自媒体专栏

    评论

    热度

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