JS闭包、作用域链的问题
var name = "The Window";

  var object = {
    name : "My Object",
    getNameFunc : function(){
      return function(){
alert(this);
        return this.name;
      };
    }
  };
  alert(object.getNameFunc()());//输出The Window

var name1 = "The Window";

  var object1 = {
    name : "My Object",
    getNameFunc : function(){
      alert(this);
var that = this;
      return function(){
        return that.name;
      };
    }
  };
  alert(object1.getNameFunc()());//输出My Object

上面的this为window对象,而下面的this为什么是object1对象,求当中的详细讲解,小子不胜感激

1个回答

很简单,你要先明白这句底发生了什么。
[code="java"]object1.getNameFunc()()[/code]

这句可以简单的拆分成两步调用:
[code="java"]
var anyFuc = object1.getNameFunc();
anyFuc();
[/code]

第一步在作用域对象object1上调用getNameFunc函数返回一个Function对象;
第二步在全局作用域上(window)直接调用这个函数对象。

这样:
第一种写法下,最终获得的name是在全局对象window下的name;
第二种写法下,先在getNameFunc中使用anyFuc的闭包保存了它的作用域object1作为that变量,然后在anyFuc中直接访问的是它,自然最终获得是object1的name

msdghs
哈尼 非常感谢!
大约 6 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问
相关内容推荐