koa-compose简单实现及使用的方法是什么

这篇“koa-compose简单实现及使用的方法是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“koa-compose简单实现及使用的方法是什么”文章吧。

场景

今年的行情真的是非常的差,而且面试的时候卷的不行。前段时间,有个朋友去面了某大厂,竟然被问到了手写一个koa-compose。那咱们今天就简单的实现一个看看到底难不难。

面试官让你实现一个场景:有一件衣服单价50元,买了num件,总和打了8折,然后运费是12元,算出买这num件衣服加上运费算上折扣需要多少钱?

首先需要实现三个函数

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

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

现在要求实现一个compose函数,然后调用这个函数,并把上面三个函数传入compose函数中,最后计算出结果。比如

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

sellTshirt(100)会计算出最后的结果。如果要计算出最后的结果,就需要将TShirtNum计算出的结果传给discount,然后discount计算出的结果传给express

此时我们可以使用reduce实现。MDN介绍reduce为:reduce()  方法对数组中的每个元素按序执行一个由您提供的 reducer 函数,每一次运行 reducer 会将先前元素的计算结果作为参数传入,最后将其结果汇总为单个返回值。

第一次执行回调函数时,不存在“上一次的计算结果”。如果需要回调函数从数组索引为 0 的元素开始执行,则需要传递初始值。否则,数组索引为 0 的元素将被作为初始值 initialValue,迭代器将从第二个元素开始执行(索引为 1 而不是 0)。

很显然compose需要返回一个函数

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

一行代码解决startNum表示我们需要购买的数量,当做reduce的初始值,然后将上一次计算的结果传给下一个函数,相当于是TShirtNum计算的结果传给discount, 也就是我们代码中实现的cur(pre)。最后即可计算出结果。redux源码就是这样实现的????

koa-compose实现

现在面试官将这三个方法改造了一下。

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
};

要求按照顺序打印结果。同时会看到每个函数中都多了一个next方法。仔细观察你会发现,next其实就是调用一个方法。我们用一个图来表示:

koa-compose简单实现及使用的方法是什么

下面我们用代码实现一下

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));

由于最后执行的是sellTshirt(100),所以需要返回一个函数在这函数内部定义一个dispatch方法,然后首次执行传入一个i为0,代表arr中的第一个函数,执行这个函数。在执行这个函数的时候需要多传入一个参数作为next, 而这个参数就是dispatch,传入的时候,i递增,代表arr中可以取下一个函数了。当执行next的时候其实就是执行dispatch。最后执行的结果为:

koa-compose简单实现及使用的方法是什么

以上就是关于“koa-compose简单实现及使用的方法是什么”这篇文章内容,相信大家都有了一定的了解,希望小编分享内容对大家有帮助,若想了解更多相关的知识内容,请关注编程之家行业资讯频道。

相关文章

支付宝万能福可以替代任何福字,没有集齐五福的用户快来试试...
TV盒子助手是一款可以远程管理智能电视、电视盒子的应用,主...
Kindle无法导入电子书怎么办?Kindle电子书阅读器是一款非常...
蓝奏云是现在很多用户下载资源时都会遇到的一款网盘,用户体...
华为Mate20怎么设置触摸屏幕亮屏?对于全面屏的手机来说,苹...
华为怎么关闭锁屏杂志?华为手机在屏幕锁定之后再次打开会看...