本篇内容主要讲解“手写合成方法的有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“手写合成方法的有哪些”吧!
前言:为什么要学习这个方法
compose简介
compose的实现
最容易理解的实现方式
手写javascript中reduce方法
redux中compose的实现
参考文章
前言:为什么要学习这个方法
遇到这个方法主要是最近在阅读redux,koa 原理 等多次遇到这个方法,为了更好地理解框架原理,于是深入学习了一下compose的实现。
然后也发现这属于函数式编程的东西,发现函数式编程是进击前端进阶的必经之路,因为像其中的纯函数的概念在redux的reducer中也展示得淋漓尽致,而保留函数计算结果的思想无论是在vue,还是react等其他框架也多处见到。
所以建议有时间可以去看下函数试编程。
接下来,就让我们学习下其中的compose函数吧!
compose简介
compose就是执行一系列的任务(函数),比如有以下任务队列
let tasks = [step1, step2, step3, step4]
每一个step都是一个步骤,按照步骤一步一步的执行到结尾,这就是一个compose
compose在函数式编程中是一个很重要的工具函数,在这里实现的compose有三点说明
第一个函数是多元的(接受多个参数),后面的函数都是单元的(接受一个参数)
执行顺序的自右向左的
所有函数的执行都是同步的
还是用一个例子来说,比如有以下几个函数
let init = (...args) => args.reduce((ele1, ele2) => ele1 + ele2, 0) let step2 = (val) => val + 2 let step3 = (val) => val + 3 let step4 = (val) => val + 4
这几个函数组成一个任务队列
steps = [step4, step3, step2, init]
使用compose组合这个队列并执行
let composeFunc = compose(...steps) console.log(composeFunc(1, 2, 3))
执行过程
6 -> 6 + 2 = 8 -> 8 + 3 = 11 -> 11 + 4 = 15
所以流程就是从init自右到左依次执行,下一个任务的参数是上一个任务的返回结果,并且任务都是同步的,这样就能保证任务可以按照有序的方向和有序的时间执行。
compose的实现
好了,我们现在已经知道compose是什么东西了,现在就来实现它吧!
最容易理解的实现方式
思路就是使用递归的过程思想,不断的检测队列中是否还有任务,如果有任务就执行,并把执行结果往后传递,这里是一个局部的思维,无法预知任务何时结束。直观上最容易理解。
const compose = function(...funcs) { let length = funcs.length let count = length - 1 let result return function f1 (...arg1) { result = funcs[count].apply(this, arg1) if (count <= 0) { count = length - 1 return result } count-- return f1.call(null, result) } }
删繁就简来看下,去掉args1参数
const compose = function(...funcs) { let length = funcs.length let count = length - 1 let result return function f1 () { result = funcs[count]() if (count <= 0) { count = length - 1 return result } count-- return f1(result) } }
这就好看很多,我们假设有三个方法,aa,bb,cc