函数式编程中代码组合(compose)如何理解?react
定义: 顾名思义,在函数式编程中,Compose就是将几个有特色的函数拼凑在一块儿, 让它们结合, 产生一个崭新的函数
代码理解:git
// 一个将小写转大写的函数 let toUpperCase = (x) => x.toUpperCase(); // 一个在字符后加!的函数 let exclaim = (x) => x + '!'; // 将两个函数组合起来, 这里假设咱们实现了compose let shout = compose(toUpperCase,exclaim); shout('js每日一题') // JS每日一题 !, 显示结果里上面两个函数的特色都应用上了
代码组合中有一个重要的概念pointfree(永远不要说出你的数据), 它的意思是指函数无须说起将要操做的数据是什么样的github
有点晦涩,咱们仍是上代码理解一下编程
// 咱们有一个将字符转换成大写而且将其空格转换为'-'的函数 // 细节的同窗应该发现这个函数暴露了一个word形参 // 根据pointfree定义,此函数非pointfree模式 let snakeCase = (word) => word.toUpperCase().replace(/\s+/ig,'-'); // 下面这个函数与上面的功能一致,但咱们能够观察到其没有数据暴露,因此其为pointfree模式 let snakeCase = compose(replace(/\s+/ig,'-'),toUpperCase)
说了这么多,他能干什么呢 ? 它可以帮助咱们减小没必要要的命名,让代码保持简洁和通用redux
上面咱们都是假设已经存在compose方法, 接下来咱们来为其实现数组
首先分析其特性promise
根据上面的示例及咱们分析的特性来实现一个最简版的函数式编程
// 这样子其实就能知足咱们上面示例的要求了 const compose = function(f, g) { return function(x) { return f(g(x)); }; };
结束了吗? 并无,咱们能够看到上面的compose示例都只是传入了两个函数,由于咱们的简版compose实现也只支持两个函数,那么若是咱们想要支持一条很长很长的管道的时候,显然上面的compose就不够用了, 接着咱们来看优秀的开源库redux的compose实现函数
// 摘自 https://github.com/reactjs/redux/blob/master/src/compose.js export default function compose(...funcs) { // 没有传入函数运行直接返回参数 if (funcs.length === 0) { return arg => arg } // 只传入一个函数,就返回其自己 if (funcs.length === 1) { return funcs[0] } // 核心代码其实就是一句reduce, reduce特性就是按顺序执行,而且将结果传递给下一次执行, 这里多说一句, reduce顺序执行多个相依赖的promise也很好用 return funcs.reduce((a, b) => (...args) => a(b(...args))) }
JS每日一题能够当作是一个语音答题社区
天天利用碎片时间采用60秒内的语音形式来完成当天的考题
群主在第二天0点推送当天的参考答案学习