this是JavaScript中的关键字,this的指向问题也一直是一个让人比较头疼的问题,
由于this是一个魔术变量,它的指向也是由函数的调用方式来决定的。下面我总结几个this的使用场景,来帮助大家更好的理解this的指向问题(欢迎留言补漏)
1、在全局中的this就指向window


2、全局调用普通函数,函数中的this指向window


3、在全局中,自调用函数中的this指向window


4、对象方法中的this指向当前对象


5、js动态绑定事件函数中的this指向当前事件源(节点对象)


6、行内绑定事件的回调函数中的this指向window


7、行内绑定事件中的this指向当前节点对象


8、延时器和定时器中的this指向window


this始终指向的都是一个对象,所以this的指向还是要看是谁来调用的
在ES6新语法中有一个特殊的函数 - 箭头函数
箭头函数中的this继承了函数当前所处的作用域,这就为开发者提供了一个很便利的方式,可控制this的指向


改变this指向其实还有更为简单粗暴的方法,也是ES6新语法:
1、bind(希望的this指向,函数参数) - 一般用在浏览器或者js自己调用的回调函数上,改变this指向,但是不立马调用(会复制函数,改变的是复制的函数中的this,原函数不变)


2、call(希望的this指向,形参1,形参2…),apply(希望的this指向,[参数1,参数2…]) - 一般用在立马调用的地方(直接改变原函数中的this)


本文详细介绍了JavaScript中this的指向问题,包括全局、函数调用、对象方法、事件处理和定时器等场景下的this行为。特别提到了箭头函数和ES6中的bind、call、apply方法如何改变this的指向。通过对这些知识点的总结,有助于开发者更好地理解和掌握JavaScript中this的用法。
8152





