模拟一个bind函数

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);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值