前端面试题,利用函数柯里化,实现如下功能

// compose(f1, f2)(f3)(f4)([1, 2, 3]) => f4(f3(f2(f1([1,2,3]))))
//
function compose() {
    //todo
    const argArr = Array.from(arguments);

    return function fn(...args) {
        return fn.call(null,)
    }
}

function f1(args) {
    return args.map((a) => a * 1);
}

function f2(args) {
    return args.map((a) => a * 2);
}

function f3(args) {
    return args.map((a) => a * 3);
}

function f4(args) {
    return args.map((a) => a + 3);
}
求大佬赐教~~
全部评论
以下是个人的见解,不知道算不算实现了,欢迎讨论: function compose() {   //todo   const argArr = Array.from(arguments); // 两个函数f1和f2   return function (arg1) {     argArr.push(arg1);  // f3     return function (arg2) {       argArr.push(arg2);  // f4       return argArr.reduce((pre, cur) => (args) => cur(pre(args)));     };   }; } 验证:
点赞 回复 分享
发布于 2021-10-17 19:10
function compose() {     const argArr = Array.from(arguments);     return function fn(args){       if(typeof args === 'function&(15889)#39;){         argArr.push(args);         return fn;       }       let res = args;       argArr.map((item) => {         res = item(res);       });       return res;     } } 后面可以继续添加f5,f6,....,最开始也可以只是f1,算是比较通用吧
点赞 回复 分享
发布于 2021-12-13 22:48

相关推荐

点赞 评论 收藏
分享
点赞 13 评论
分享
牛客网
牛客企业服务