JavaScript中this对象原理简洁说明

今天看了阮一峰大神的博客文章:JavaScript 的this原理,把纠结很久的this的指向终于理解清楚了

原文:http://www.ruanyifeng.com/blog/2018/06/javascript-this.html

现在来说说如何区分不同情况下的this对象指向,如下所示:

var obj = {
  num: 12,    
  foo: function() { console.log(this.num) }          
}

var num = 2;
var fun = obj.foo;

obj.foo(); // 12
fun(); // 2

obj.foo() 即为调用obj对象下的foo属性对应的方法,但是运行环境还是在对象obj中,故此时的this指向obj对象,故输出为12;

对于 var fun = obj.foo,相当于是将obj对象下的foo函数在内存中的地址赋值给了变量fun,而变量fun却是一个全局变量,所以fun() 的运行环境其实是在window对象下,fun()运行起来后其下的函数foo里的this指向window对象,故此时输出为2;

 

这是我看了大神博客后的理解加总结,如果有什么不对的地方,希望指正。

posted @ 2018-11-13 13:52  secretAngel  阅读(188)  评论(0编辑  收藏  举报