zoukankan      html  css  js  c++  java
  • promisify,promisifyAll,promise.all实现原理

    1.promisify

    function toPrimisify (fn){
    return function (...args){
          return new Promise(function(resolve,reject){
               fn(...args,function(err,data){
                err?reject(err):resolve(data)
              })
         })
    }
    let read2 = toPrimisify(fs.readFile);
    fs.readFile'./2.txt','utf8').then(res=>{console.log(res)});

    2.promisifyAll

    function toPromisifyAll(obj){

    Object.keys(obj).forEach((item,index)=>{

    if(typeof obj[item]=='function')
    obj[item+'Async'] =toPrimisify(obj[item])
    })
    }
    toPromisifyAll(fs);
    fs.readFileAsync('./2.txt','utf8').then(res=>{console.log(res)});

    3.promise.all

    function promiseAll(promises){
         return new Promise(function(resolve,reject){
                if(!Array.isArray(promises)){
                 return reject(new TypeError("argument must be anarray"))
               }
        var countNum=0;
        var promiseNum=promises.length;
        var resolvedvalue=new Array(promiseNum);
        for(var i=0;i<promiseNum;i++){
          (function(i){
             Promise.resolve(promises[i]).then(function(value){
                countNum++;
               resolvedvalue[i]=value;
              if(countNum===promiseNum){
                  return resolve(resolvedvalue)
              }
           },function(reason){
            return reject(reason)
          )
         })(i)
        }
    })
    }

    var p1=Promise.resolve(1),
    p2=Promise.resolve(2),
    p3=Promise.resolve(3);

    promiseAll([p1,p2,p3]).then(function(value){
    console.log(value)

    })

  • 相关阅读:
    [Unity UGUI]ScrollRect效果大全
    Lua元表
    [译]使用AssetBundle Manader
    [Unity 设计模式]桥接模式(BridgePattern)
    [Unity 设计模式]IOC依赖倒置
    基于Shader实现的UGUI描边解决方案
    UGUI实现不规则区域点击响应
    使用消息分发机制降低程序中的耦合度
    使用IDA静态分析解密《舰娘Collection》的lua脚本
    定制自己的Unity脚本模板
  • 原文地址:https://www.cnblogs.com/qiyc/p/10453616.html
Copyright © 2011-2022 走看看