js中this的指向问题以及call()和apply()

本文详细介绍了JavaScript中函数对象的call()和apply()方法,它们用于改变函数执行时的this对象。当你调用这两个方法时,第一个参数会作为函数内部的this值。call()允许后续参数直接传递,而apply()则需将参数放在数组中传递。此外,文章还阐述了this在不同调用场景下的指向规则,包括函数调用、方法调用、构造函数调用以及使用call()和apply()的情况。

js中call()和apply()

	call和apply都是函数对象的方法,需要通过函数对象来调用
	当函数调用call()和apply()都会调用函数执行
	在调用call()和apply()可以将第一个对象指定为第一个参数,此时这个对象将会成为函数执行时的thistongyi
	call()方法可以将实参在对象之后一次传递
	apply()方法需要将需要将实参封装到一个数组中统一传递
this的指向
	以函数形式调用时,this永远都是window
	以方法形式调用时,this是调用方法的对象
	以构造函数的形式调用时,this是新创建的的那个对象
	使用call()和apply()调用时,this是指定的那个对象
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值