前端编程题

本文介绍了JavaScript中如何改变函数内部的this指向,包括使用call()、apply()和bind()方法。call()和apply()的区别在于传递参数的方式,call()接受单独参数,apply()接收数组形式的参数。bind()方法则允许将函数绑定到特定对象,创建一个新的函数。这些技巧对于理解和使用JavaScript对象及函数至关重要。

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

封装函数f,使f的this指向指定的对象

1、call() 方法是预定义的 JavaScript 方法。它可以用来调用所有者对象作为参数的方法。

通过 call(),您能够使用属于另一个对象的方法。

function bindThis(f, oTarget) {
    return function(x,y){
        return f.call(oTarget,x,y);
    }
}

2、apply() 方法与call()方法类似,唯一区别是:

call() 方法分别接受参数。

apply() 方法接受数组形式的参数。

Javascrip中每个函数都会有一个Arguments对象实例arguments,它引用着函数的实参,可以用数组下标的方式"[]"引用arguments的元素。

function bindThis(f, oTarget) {
    return function(){
        return f.apply(oTarget,arguments);
    }
}

3、Function.prototype.bind()方法

bind()方法主要就是将函数绑定到某个对象,bind()会创建一个函数,函数体内的this对象的值会被绑定到传入bind()第一个参数的值,例如,f.bind(obj),实际上可以理解为obj.f(),这时,f函数体内的this自然指向的是obj。

function bindThis(f, oTarget) {
    return f.bind(oTarget);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值