zoukankan      html  css  js  c++  java
  • [Javascript] Understand Function Composition By Building Compose and ComposeAll Utility Functions

    Function composition allows us to build up powerful functions from smaller, more focused functions. In this lesson we'll demystify how function composition works by building our own compose and composeAll functions.

    // __test__ 
    
    import {add, inc, dbl, addInc, addIncDbl} from '../function/custom-compose';
    
    describe('basic fns', () => {
        "use strict";
        test('add', () => {
            const res = add(1,2);
            const expected = 3;
            expect(res).toBe(expected);
        });
    
        test('inc', () => {
            const res = inc(2);
            const expected = 3;
            expect(res).toBe(expected);
        });
    
        test('dbl', () => {
            const res = dbl(2);
            const expected = 4;
            expect(res).toBe(expected);
        });
    });
    
    describe('compose', () => {
        "use strict";
        test('add then inc', () => {
            const res = addInc(4, 2);
            const expected = 7;
            expect(res).toBe(expected);
        });
    });
    
    describe('composeAll', () => {
        "use strict";
       test('add, inc then dbl', () => {
           const res = addIncDbl(2, 3);
           const expected = 12;
           expect(res).toBe(expected);
       }) ;
    });
    /*
    * Utils
    * */
    const compose = (f, g) => (...args) => f(g(...args));
    
    const composeAll = (...fns) => fns.reduce(compose);
    /*
    * Libs
    * */
    export const add = (a, b) => a + b;
    
    export const inc = (a) => a + 1;
    
    export const dbl = (a) => a * 2;
    
    export const addInc = compose(inc, add);
    
    export const addIncDbl = composeAll(dbl, inc, add);
  • 相关阅读:
    jquery中ajax请求的使用和四个步骤示例
    jzoj6094
    2019.03.27【GDOI2019】模拟 T3
    AGC019F
    浅谈高维前缀和
    刷题清单
    为什么要遍历两次?——个人对于kosaraju算法的理解
    我的黑客和渗透测试学习路线
    一个假猪套神器:NET CAT-NC
    kali linux(二):使用与介绍
  • 原文地址:https://www.cnblogs.com/Answer1215/p/6667130.html
Copyright © 2011-2022 走看看