函数式编程-组合函数compose的4种实现方式

        函数式编程中,经常提到组合函数compose,调用方式有compose(f,g,h)、compose(compose(f,g),h)等等,返回结果是一个新函数,redux库中也有相应实现。本文就compose,介绍4种实现方式。

1. 方式一:使用JavaScript数组的reduce函数,从前往后迭代函数数组funcs, 每次记录生成的新函数prev,下次再将函数cur的求值结果作为新函数prev的参数
const compose = (...funcs) => {
    if(funcs.length === 0) {
        return arg => arg;
    }
    
    if(funcs.length === 1) {
        return funcs[0];
    }

    return funcs.reduce((prev, cur) => {
       return (...args) => {
           return prev(cur(...args));
        } 
    });
}
2. 方式二:使用JavaScript数组的reduceRight函数,从后往前迭代函数数组funcs,每次记录函数求值结果prev
const compose = (...funcs) => {
    if(funcs.length === 0) {
        return arg => arg;
    }
    
    if(funcs.length === 1) {
        return funcs[0];
    }

    return (...args) => {
        return funcs.reduceRight((prev, cur, i) => {
            let param = i === funcs.length - 1 ? args : [ prev ];
            return cur(...param);
        }, args);
    }
}
3. 方式三:使用for...of,从前往后迭代函数数组funcs, 每次记录生成的新函数com,下次迭代时将函数com赋值给prev,并将函数cur的求值结果作为新函数prev的参数
const compose = (...funcs) => {
    let com = arg => arg;
    for(const cur of funcs) {
        const prev = com;
        com = (...args) => prev(cur(...args));
    }
    return com;
}
4. 方式四:使用for,从后往前迭代函数数组funcs,每次记录函数求值结果res
const compose = (...funcs) => {
    if(funcs.length === 0) {
        return arg => arg;
    }

    return (...args) => {
        let res, len = funcs.length;    
        for(let i = len - 1; i >=0; i--) {
            param = i === len - 1 ? args : [ res ];
            res = funcs[i](...param);
        }
        return res;
    }
}

        其中,方式一和方式三是从前往后迭代,方式二和方式四是从后往前迭代。

注:以上,如有不合理之处,还请帮忙指出,大家一起交流学习~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值