欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

koa-compose簡單實現(xiàn)及使用的妙處

 更新時間:2023年04月11日 10:00:04   作者:翰玥  
這篇文章主要為大家介紹了koa-compose簡單實現(xiàn)及使用的妙處詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

場景

今年的行情真的是非常的差,而且面試的時候卷的不行。前段時間,有個朋友去面了某大廠,竟然被問到了手寫一個koa-compose。那咱們今天就簡單的實現(xiàn)一個看看到底難不難。

面試官讓你實現(xiàn)一個場景:有一件衣服單價50元,買了num件,總和打了8折,然后運費是12元,算出買這num件衣服加上運費算上折扣需要多少錢?

首先需要實現(xiàn)三個函數(shù)

const express = (total) => {
  return total + 12;
};
const discount = (total) => {
  return total * 0.8;
};
const TShirtNum = (num) => {
  return 50 * num;
};

TShirtNum代表num件衣服需要的費用,discount表示打了8折之后的費用,express表示算上運費的費用。

現(xiàn)在要求實現(xiàn)一個compose函數(shù),然后調(diào)用這個函數(shù),并把上面三個函數(shù)傳入compose函數(shù)中,最后計算出結(jié)果。比如

const sellTshirt = compose([TShirtNum, discount, express]);
sellTshirt(100)

sellTshirt(100)會計算出最后的結(jié)果。如果要計算出最后的結(jié)果,就需要將TShirtNum計算出的結(jié)果傳給discount,然后discount計算出的結(jié)果傳給express。

此時我們可以使用reduce實現(xiàn)。MDN介紹reduce為:reduce()  方法對數(shù)組中的每個元素按序執(zhí)行一個由您提供的 reducer 函數(shù),每一次運行 reducer 會將先前元素的計算結(jié)果作為參數(shù)傳入,最后將其結(jié)果匯總為單個返回值。

第一次執(zhí)行回調(diào)函數(shù)時,不存在“上一次的計算結(jié)果”。如果需要回調(diào)函數(shù)從數(shù)組索引為 0 的元素開始執(zhí)行,則需要傳遞初始值。否則,數(shù)組索引為 0 的元素將被作為初始值 initialValue,迭代器將從第二個元素開始執(zhí)行(索引為 1 而不是 0)。

很顯然compose需要返回一個函數(shù)

const compose = (funcArr) => (startNum) => funcArr.reduce((pre, cur) => cur(pre), startNum) 

一行代碼解決。startNum表示我們需要購買的數(shù)量,當做reduce的初始值,然后將上一次計算的結(jié)果傳給下一個函數(shù),相當于是TShirtNum計算的結(jié)果傳給discount, 也就是我們代碼中實現(xiàn)的cur(pre)。最后即可計算出結(jié)果。redux源碼就是這樣實現(xiàn)的??

koa-compose實現(xiàn)

現(xiàn)在面試官將這三個方法改造了一下。

const express = (total, next) => {
  console.log("starting, express"); // 3
  next(total + 12);
  console.log("ending, express"); // 4
};
const discount = (total, next) => {
  console.log("starting, discount"); // 2
  next(total * 0.8); 
  console.log("ending, discount"); // 5
};
const TShirtNum = (num, next) => {
  console.log("starting, TShirtNum"); // 1
  next(15 * num); 
  console.log("ending, TShirtNum"); // 6
};

要求按照順序打印結(jié)果。同時會看到每個函數(shù)中都多了一個next方法。仔細觀察你會發(fā)現(xiàn),next其實就是調(diào)用下一個方法。我們用一個圖來表示:

下面我們用代碼實現(xiàn)一下

function compose(arr) {
  let result;
  return function (ctx) {
    let dispatch = function (i, ctx) {
      let fn;
      if (i < arr.length) {
        fn = arr[i];
      }
      if (i === arr.length) {
        result = ctx;
        return;
      }
      return fn(ctx, dispatch.bind(null, ++i));
    };
    dispatch(0, ctx);
    return result;
  };
}
const sellTshirt = compose([TShirtNum, discount, express]);
console.log(sellTshirt(100));

由于最后執(zhí)行的是sellTshirt(100),所以需要返回一個函數(shù)。在這個函數(shù)內(nèi)部定義一個dispatch方法,然后首次執(zhí)行傳入一個i為0,代表arr中的第一個函數(shù),執(zhí)行這個函數(shù)。在執(zhí)行這個函數(shù)的時候需要多傳入一個參數(shù)作為next, 而這個參數(shù)就是dispatch,傳入的時候,i遞增,代表arr中可以取下一個函數(shù)了。當執(zhí)行next的時候其實就是執(zhí)行dispatch。最后執(zhí)行的結(jié)果為:

其實就是用遞歸的思想去實現(xiàn)。大家可以去看下koa-compose的源碼基本上也就是這樣。

以上就是koa-compose簡單實現(xiàn)及使用的妙處的詳細內(nèi)容,更多關(guān)于koa-compose簡單實現(xiàn)的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • node.js中的fs.fchown方法使用說明

    node.js中的fs.fchown方法使用說明

    這篇文章主要介紹了node.js中的fs.fchown方法使用說明,本文介紹了fs.fchown方法說明、語法、接收參數(shù)、使用實例和實現(xiàn)源碼,需要的朋友可以參考下
    2014-12-12
  • 基于node的cli工具開發(fā)使用詳解

    基于node的cli工具開發(fā)使用詳解

    這篇文章主要為大家介紹了基于node的cli工具開發(fā)使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-03-03
  • 如何優(yōu)雅地在Node應(yīng)用中進行錯誤異常處理

    如何優(yōu)雅地在Node應(yīng)用中進行錯誤異常處理

    這篇文章主要介紹了如何優(yōu)雅地在Node應(yīng)用中進行錯誤處理,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-11-11
  • Node.js中的模塊系統(tǒng)介紹

    Node.js中的模塊系統(tǒng)介紹

    這篇文章介紹了Node.js中的模塊系統(tǒng),對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-04-04
  • npm配置國內(nèi)鏡像資源+淘寶鏡像的方法

    npm配置國內(nèi)鏡像資源+淘寶鏡像的方法

    這篇文章主要介紹了npm配置國內(nèi)鏡像資源+淘寶鏡像的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • nvm版本導(dǎo)致npm?install報錯Unexpected?token?'.'的解決辦法

    nvm版本導(dǎo)致npm?install報錯Unexpected?token?'.'的解決辦法

    最近做項目遇到npm install 的問題,下面這篇文章主要給大家介紹了關(guān)于nvm版本導(dǎo)致npm?install報錯Unexpected?token?'.'的解決辦法,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2022-07-07
  • 使用nodejs爬取前程無憂前端技能排行

    使用nodejs爬取前程無憂前端技能排行

    這篇文章主要介紹了使用nodejs爬前程無憂前端技能排行,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-05-05
  • express中static中間件的具體使用方法

    express中static中間件的具體使用方法

    這篇文章主要介紹了express中static中間件的具體使用方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-10-10
  • Node.js 使用流實現(xiàn)讀寫同步邊讀邊寫功能

    Node.js 使用流實現(xiàn)讀寫同步邊讀邊寫功能

    本文通過代碼給大家介紹了Node.js 使用流實現(xiàn)讀寫同步邊讀邊寫功能,非常不錯,具有參考借鑒價值,需要的額朋友參考下吧
    2017-09-09
  • Node.Js中實現(xiàn)端口重用原理詳解

    Node.Js中實現(xiàn)端口重用原理詳解

    這篇文章主要介紹了Node.Js中實現(xiàn)端口重用原理詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05

最新評論