Ada*_*m J 3 javascript arguments
我看到这个快捷方式作为代码 Kata 的答案,但我很难理解下面的例子在做什么。
function func(fn) {
return fn.bind.apply(fn, arguments);
}
Run Code Online (Sandbox Code Playgroud)
到目前为止,我的理解是 bind 创建了一个类似于执行以下操作的新函数:
function func(fn) {
return function () {
return fn.apply(fn, arguments);
};
}
Run Code Online (Sandbox Code Playgroud)
是这种情况吗?任何更清晰的答案或正在发生的事情都会很棒。
fn.bind
Run Code Online (Sandbox Code Playgroud)
只是
Function.prototype.bind
Run Code Online (Sandbox Code Playgroud)
fn.bind(arguments[0]/* doesn't matter, it's fn*/, arguments[1], arguments[2], etc.)
Run Code Online (Sandbox Code Playgroud)
所以绑定函数被调用,参数是funcafter的参数fn。
另一种写法是:
function func(fn) {
var args = [].slice.call(arguments, 1);
return function () {
var localArgs = [].slice.call(arguments);
return fn.apply(fn, args.concat(localArgs));
};
}
Run Code Online (Sandbox Code Playgroud)
调用的上下文是初始函数 ( arguments[0])的事实肯定只是一个副作用。重要的是我们用函数包装参数,但可以动态传递其他参数。
示例 1,包装所有参数:
function add(a,b){
return a+b
}
var f = func(add, 2 ,3); // f is a function which will always apply add to 2 and 3
console.log(f()) // logs 5
Run Code Online (Sandbox Code Playgroud)
例2,柯里化:
function multiply(a,b){
return a*b
}
var multBy2 = func(multiply, 2);
console.log(multBy2(3)) // logs 6
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1549 次 |
| 最近记录: |