JavaScript中修改this指向的方法(更换调用对象)

本文介绍了JavaScript中改变函数上下文的三种方法:call、apply和bind。通过实例展示了如何使用这些方法将函数绑定到不同对象上,从而改变this的指向。call和apply的主要区别在于传递参数的方式,call直接传入参数列表,而apply则是以数组形式传递。bind则用于创建一个新的函数,保持原函数的this不变,但可以预先设置参数。

主要有三种方法:call,apply,bind
1、call

 obj.sex.call(obj1,"忠")

var obj = {
name:'张飞',
sex:function(a){console.log(this.name,"无法确定性别!",a)}
}
obj.sex('飞')   // 张飞 无法确定性别! 飞
 
var obj1 = {
name:"黄忠"
}
obj.sex.call(obj1,"忠")    // 黄忠 无法确定性别! 忠
2、apply

obj.sex.call(obj1,["忠"]) 

var obj = {
name:'张飞',
sex:function(a){console.log(this.name,"无法确定性别!",a)}
}
obj.sex('飞')   // 张飞 无法确定性别! 飞
 
var obj1 = {
name:"黄忠"
}
obj.sex.call(obj1,["忠"])    // 黄忠 无法确定性别! 忠
3、bind

obj.sex.bind(obj1)

var obj = {
name:'张飞',
sex:function(a){console.log(this.name,"无法确定性别!",a)}
}
obj.sex('飞')   // 张飞 无法确定性别! 飞
 
var obj1 = {
name:"黄忠"
}
var str = obj.sex.bind(obj1)
 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值