js之call,apply的实现

目录

 

call的实现

apply的模拟实现

 


call的实现

call方法使用一个指定的 this 值和单独给出的一个或多个参数来调用一个函数

call的语法:

fun.call(thisArg, arg1, arg2, ...)

如:

let product = {
    name : 'cat'
}
function show(price) {
    this.price = price;
    console.log(this.name);
    console.log(this.price);
}
show.call(product,100);

也就相当于

product = {
    name : 'cat',
    price : 100,
    show:function () {
        console.log(this.name);
        console.log(this.price);
    }
}

所以模拟的步骤可分为:

  1. 将函数设为对象的属性
  2. 执行该函数
  3. 删除该函数
Function.prototype.call1 = function (obj) {
    obj = obj || window;//obj为空时指向window
    let args = [...arguments].slice(1);//获取参数
    obj.fn = this;//获取调用call的函数
    let res = obj.fn(...args);
    delete  obj.fn;
    return res;
}

apply的模拟实现

apply() 方法调用一个具有给定this值的函数,以及作为一个数组(或类似数组对象)提供的参数。

apply的语法:

func.apply(thisArg, [argsArray])

模拟实现:

Function.prototype.apply1 = function (obj) {
    obj = obj || window;
    obj.fn = this;
    let res, args = [...arguments][1];
    if( !args){
       res = obj.fn();
    }else {
        res = obj.fn(args);
    }
    delete  obj.fn;
    return res;
}

 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值