原生js实现 bind,附带实现了apply

// apply实现

Function.prototype.applyA = function (_this, arr) {

    if (!_this) _this = Object.create(null);

    _this.fn = this;

    // 参数字符串化处理

    var res = eval("_this.fn(" + arr + ")");

    delete _this.fn;

    return res;

}

Function.prototype.bindA = function (_this) {

    if (!_this) { _this = Object.create(null) };

    var self = this;

    var resFn = function () {

        var arg = arguments;

        var pa = [];

        // 参数数组化,原始js实现

        for (var i = 0; i < arg.length; i++) { pa.push(arg[i]) };

        return self.applyA(_this, pa);

    };

    return resFn;

};

function sum(a, b) {

    return this.v + a + b;

};

sum.bindA({v:'10'},1,2);

实现主要关键步骤

1.创建隐式调用,改变this指向为绑定的this

2.原生实现参数转换通过遍历和eval

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值