js中call和apply的用法和区别

javaScript 中通过call或者apply用来代替另一个对象调用一个方法,将一个函数的对象上下文从初始的上下文改变为指定的新对象。简单的说就是改变函数中this的指向

基本用法
function Fun(){
	this.name = "fun";
	this.say = function(){
		console.log(this.name);
		console.log(arguments);
	}
}

let people = {
	name:"test"
}

let f = new Fun();

f.say.call(people,[1,2,3],1,3,'hello')
f.say.apply(people,[1,3]);

区别

运行上述代码,可以看出,调用Fun中的say方法用call和apply都可以改变this.name 的值为people对象的name值,两者的区别在于
call支持多个参数

f.say.call(people,[1,2,3],1,3,'hello') //第一个参数为需要改变this指向的对象,其他参数都是调用方法传递进去的参数

apply只支持两个参数

f.say.apply(people,[1,3]);//第一个参数为需要改变this指向的对象,第二个参数为调用方法传递的参数,只支持数组格式


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值