zoukankan      html  css  js  c++  java
  • nodejs 几个不错的callback 以及promise 转换处理工具

    nodejs 的一步调用经历了,callback -> promise -> async await(语法糖) 模式的转变
    以下是几个整理

    nodejs 自带的callback -> promise 处理

    util 工具包

    • 参考使用
     
    const util = require("util")
    function login({name,age},cb) {
        cb(null,{name,age});
    }
     const fn = util.promisify(login);
     (async () => {
       let result = await fn({
            name:"dalong",
            age:333
        })
        console.log(result)
     })()
     

    pify

    一个很不错的callback -> promise 转换处理

    • 参考使用
    const pify = require("pify")
    function login({name,age},cb) {
        cb(null,{name,age});
    }
     const fn = pify(login);
     (async () => {
       let result = await fn({
            name:"dalong",
            age:333
        })
        console.log(result)
     })()
     

    universalify

    这个工具就更方便了可以,callback -> promise-> 也可以promise-> promise

    • 参考使用
      callback->prormise
     
    const universalify = require("universalify");
    function login({name,age},cb) {
        cb(null,{name,age});
    }
    const fn = universalify.fromCallback(login);
    (async()=>{
       const result = await fn({
            name:"dalong",
            age:333
        })
        console.log(result)
    })()
    
    

    promise -> promise

    const universalify = require("universalify");
    async function   promiseFn({name,age}){
        return {
            name,
            age,
            version:"v2"
        } 
    };
    const fn = universalify.fromPromise(promiseFn);
    (async()=>{
       const result = await fn({
            name:"dalong",
            age:333
        })
        console.log(result)
    })()
     
     

    ## 说明
    以上是几个整理,实际上类似的npm 包还是很多的,可以通过npm官方仓库查找相关的

    参考资料

    https://www.npmjs.com/package/universalify
    https://www.npmjs.com/package/pify

  • 相关阅读:
    买书问题
    结队开发项目—NABC模型
    《梦断代码》读后感3
    <梦断代码>读后感2
    四则运算3
    数组结对开发
    BICEP单元测试——随机四则运算升级版
    新 四则运算题目 修改
    新 四则运算题目 C++
    新 四则运算题目设计思路
  • 原文地址:https://www.cnblogs.com/rongfengliang/p/13092538.html
Copyright © 2011-2022 走看看