Function.prototype.bind = function(context) {
var self = this; // 保存原函数
return function() { // 返回一个新的函数
return self.apply(context,arguments); // 执行新的函数的时候,会把之前传入的context当作新函数体的this (执行)
};
};
var obj = {
name: 'sven'
};
var func = function() {
console.log(this.name);
}.bind(obj);
func(); // "sven"
一个稍微复杂一点的bind函数:
Function.prototype.bind = function() {
var self = this; // 保存原函数
var context = [].shift.call(arguments); // 需要绑定的this上下文
var args = [].slice.call(arguments); // 将剩余的参数转化为数组
return function() { // 返回一个新的函数
return self.apply(context,[].concat.call(args,[].slice.call(arguments)));
// 执行新的函数的时候,会把之前传入的context当作新函数体内的this
// 并且结合两次分别传入的参数,作为新函数的参数。
};
};
var obj = {
name: 'sven'
};
var func = function(a,b,c,d) {
console.log(this.name); // "sven"
console.log([a,b,c,d]); // [1,2,3,4]
}.bind(obj,1,2);
func(3,4);