javascript实现方法调用与方法触发小结
程序员文章站
2022-06-20 20:11:14
在js中,this关键字是一个比较让人有意思的东西,但是它的指向经常让初学者摸不着头脑。
其实要理解这个关键字,需要理清两个问题——“方法的调用和方法的触发”
...
在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指向的是调用者,而触发者只是推进调用者执行指定方法而已。
推荐阅读
-
Android编程使用WebView实现与Javascript交互的方法【相互调用参数、传值】
-
Android实现计时与倒计时的常用方法小结
-
JavaScript中循环遍历Array与Map的方法小结
-
C#实现Windows Form调用R进行绘图与显示的方法
-
javascript实现方法调用与方法触发小结
-
JavaScript观察者模式(publish/subscribe)原理与实现方法
-
TP5(thinkPHP5)框架使用ajax实现与后台数据交互的方法小结
-
JavaScript 复制对象与Object.assign方法无法实现深复制
-
JavaScript实现浅拷贝与深拷贝的方法分析
-
Javascript与jQuery方法的隐藏与显示实现方法