【js】使用 apply 调用函数

这篇博客探讨了JavaScript中使用apply调用函数的方法。介绍了如何实现callIt函数,该函数接受一个主函数fn和其他参数,使用apply确保fn被正确调用。文章强调了由于arguments对象不是真正的数组,所以需要将其转换为数组才能使用slice方法。同时,还提出了另一种通过循环遍历的方式。此外,还解释了partialUsingArguments函数的实现,它返回一个新函数result,当调用result时,会结合原始参数和新参数一起通过apply调用fn。

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

一、题目描述

实现函数 callIt,调用之后满足如下条件

1、返回的结果为调用 fn 之后的结果

2、fn 的调用参数为 callIt 的第一个参数之后的全部参数

示例1

输入

输出

arguments并非真正的数组,因此要获得callIt的第一个参数之后的所有参数,不能直接使用slice方法截取,需要先将arguments转换为真正的数组才行。有两种常见的方法:

  • 使用slice方法:var args = Array.prototype.slice.call(arguments);
  • 循环遍历逐一填入新数组。在获得了args之后,就可以调用apply来执行传入的函数参数。

1.Array.prototype.slice.call(arguments,1)

function callIt(fn) {
    //将arguments转化为数组后,截取第一个元素之后的所有元素
    var args = Array.prototype.slice.call(arguments,1);
    //调用fn
    var result = fn.apply(null,args);
    return result;
}

或者:

function callIt(fn) {
    return fn.apply(this,[].slice.call(arguments,1));
}

2.循环遍历

function callIt(fn) {
    var args=[];
    for(var i=1;i<arguments.length;i++){
        args.push(arguments[i]);
    }
    var result=fn.apply(null,args);
    return result;
}

3.获取全部参数,然后去掉第一个

function callIt(fn) {
    var arr=Array.prototype.slice.call(arguments);
    arr.shift();
    return fn.apply(this,arr);  
}

二、题目描述

实现函数 partialUsingArguments,调用之后满足如下条件:

1、返回一个函数 result

2、调用 result 之后,返回的结果与调用函数 fn 的结果一致

3、fn 的调用参数为 partialUsingArguments 的第一个参数之后的全部参数以及 result 的调用参数

示例1

输入

输出

arguments不能用slice方法直接截取,需要先转换为数组,var args = Array.prototype.slice.call(arguments);

合并参数可以使用concat方法,并且也需要将arguments先转换为数组才能使用concat进行合并。最后使用apply执行传入的函数即可。 

function partialUsingArguments(fn) {
    var arr=[].slice.call(arguments,1);
    var result=function(){
        var arr1=[].slice.call(arguments);
        return fn.apply(this,arr.concat(arr1));
    }
    return result;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值