在js中,this关键字是一个比较让人有意思的东西,但是它的指向经常让初学者摸不着头脑。
其实要理解这个关键字,需要理清两个问题——“方法的调用和方法的触发”
下面先看一段代码
<!doctype html> <html> <head> <meta charset="utf-8"> <title>function</title> <script> function showthis(){ console.info(this); } function test1(){ this.f=showthis; } function test2(){ this.f=function(){ showthis(); } } showthis();//window new test1().f();//test1 new test2().f();//window </script> </head> <body> </body> </html>
20行打印出window对象,这个很容易理解,但是21行打印出test1的实例对象,而22行却打印出window对象。查看test1和test2的构造,发现方法f最终都执行了showthis方法。但是showthis中的this指向却不同。这是因为test1中的f方法直接指向showthis,new test1().f()是以test1 的实例直接调用showthis方法,调用者是test1的实例。而new test2().f()是在test2的实例方法f中触发window对象的showthis方法,其中的this就是指向其调用者window而不是触发者test2的实例。
至此可以发现。this指向的是调用者,而触发者只是推进调用者执行指定方法而已。
如对本文有疑问, 点击进行留言回复!!
javascript从入门到跑路-----小文的js学习笔记(19)------- js的垃圾回收机制
Agora 开源 | 一个 Demo,帮你快速实现社交直播四大场景
网友评论