js之call,apply的实现

本文深入解析了JavaScript中call和apply方法的工作原理,详细介绍了它们的语法和使用场景,并通过模拟实现帮助读者理解这两个方法背后的机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

 

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;
}

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值