在函数式编程,响应式编程中,我们应尽量采用不可变和纯函数来增加确定性,在方法的输入,输出,计算中,最难以控制的就是输入,我们来聊聊如何控制输入
部分应用
//假设我没有这么一个方法,我们只提前知道id
funcation orderHandle(id,order,callback){
}
//这样的代码就非常清晰
function orderhandle(order,callback){
orderhandle("dadadad3",order,callback)
}
但这样过于繁琐,我们可以书写一个工具
var partial=(fn,...preserArgs)=>(...lasteArgs)=>fn(...preserArgs,...lasteArgs)
function sum(a, b, c) {
return a + b + c;
}
// 使用 partial 函数来创建一个新函数,这个新函数预先设定了第一个参数为 1
var sumWithOne = partial(sum, 1);
// 现在,sumWithOne 是一个新函数,它接受两个参数,并将 1 作为第一个参数传递给 sum
console.log(sumWithOne(2, 3)); // 输出: 6
// 也可以再次使用 partial 来创建另一个函数,这次设定前两个参数为 1 和 2
var sumWithOneAndTwo = partial(sumWithOne, 2);
// sumWithOneAndTwo 只接受一个参数,并将 1 和 2 作为前两个参数传递给 sum
console.log(sumWithOneAndTwo(3)); // 输出: 6