将使用回调函数作为参数的函数改造为返回 Promise 的一个具体例子
data:image/s3,"s3://crabby-images/466ab/466ab5197082caf6041d975b7a9fa43c14d06741" alt="将使用回调函数作为参数的函数改造为返回 Promise 的一个具体例子"
我开发了一个函数 loadScript,可以动态加载指定的本地 JavaScript 文件。源代码如下:
然后开发一个函数 promisify
,可以将任意传递进来的函数 f,改造成返回参数类型为 Promise 的新函数。
具体的消费方式:
其中 1.js 的内容:
下面我们进行单步调试。
待改造的 loadScript,包含两个函数:
data:image/s3,"s3://crabby-images/e5975/e5975cb4c9542403c4b093ff41296e46d127c8fc" alt=""
调用 promisify,返回一个新的函数。
data:image/s3,"s3://crabby-images/e14e8/e14e8a220f6c844afab6a1408d3728968691eff8" alt=""
这个新的函数包含一个闭包 f,可以调用没有 promisify 之前的旧函数。
data:image/s3,"s3://crabby-images/6ec99/6ec99609288a022ac5dcca45a4d40b112c041ab6" alt=""
使用这个新函数加载 1.js:
data:image/s3,"s3://crabby-images/36cce/36cce1581705b7e19f7c0ef41cd5991def1fd598" alt=""
进入这个新函数内部,执行 executor body:
data:image/s3,"s3://crabby-images/5ff57/5ff57a5d98181feb9e99dbfbc253b1d18a4f3cc2" alt=""
在函数体内部可以随时访问 callback:
data:image/s3,"s3://crabby-images/30e0e/30e0eb0bf8d1667180f472279d889183e8d274a8" alt=""
我们期望 script onload 事件发生时,会使用 Promise 自带的 resolve 和 reject 传递参数,因此自己编写了一个 callback 函数,在这个 callback 函数里,使用 Promise 的 resolve 投递结果。
并且期望将这个 callback 函数,传递给原始的 loadScript 函数内部。我们通过 function
原型链上的 call 函数,就达到了调用原始的 loadScript 函数的目的。
data:image/s3,"s3://crabby-images/2d563/2d56301ea9e0840c7ba30083708359659557ed5a" alt=""
并且此时的 callback 函数,确实是我们在 promisify 函数内编写的使用 Promise resolve 传递结果的函数。
data:image/s3,"s3://crabby-images/93139/9313923aa14a6e4008f52b9e2d6ff2c9ace1587a" alt=""
稍后,script.onload 异步触发:
data:image/s3,"s3://crabby-images/fe3ba/fe3ba2b7531e73b393ae7b4f60cc89fcaa62f857" alt=""
通过 resolve,将加载完毕的 script 元素,传递给 promise 对象通过 then 注册的回调函数。
data:image/s3,"s3://crabby-images/59f89/59f898565e8415e44800ffc050722017c6fd1a61" alt=""
data:image/s3,"s3://crabby-images/f82ab/f82ab838d3877797b86a6d9c072bfb3e7ba88d57" alt=""
版权声明: 本文为 InfoQ 作者【Jerry Wang】的原创文章。
原文链接:【http://xie.infoq.cn/article/50f99e428cdb4418862690781】。文章转载请联系作者。
评论