zoukankan      html  css  js  c++  java
  • 《Professional Javascript For Web Developers 3rd Edition》读书笔记:javascript闭包中的this对象

      通常,this对象指向函数运行时的上下文对象。当在全局函数中时,this指向window对象(非strict模式)或undefined(strict模式),当在对象函数中使用时,this指向这个对象。但是在匿名函数中,this并不指向该对象,而是window对象(非strict模式)。在javascript闭包中,这种情况尤为多见:

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

      为什么匿名函数中的this并不等同于该对象呢?原来,在每个function被调用的时候,自动就有了两个特殊的变量:this和arguments。但是,嵌套的内部函数不能直接获取外部函数中的this和arguments。有什么变通的方法?那就是将它们存到另外的变量中去,这样函数闭包就可以访问了:

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

    有时候,this会得到你意想不到的结果,比如:

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

    第一行和第二行还好理解,结果不出所料,第三行就是奇葩了!只是执行了一次赋值,结果却截然不同。这是为什么呢?书上的解释是这样的:因为第三行的赋值表达式的值只是function本身,并没有维护this的值,所以就指向window对象了。当然,很少人会这么有雅兴用第三种方式写,只不过说明细微的语法差别会造成this结果的差异。

  • 相关阅读:
    poj3277 City Horizon
    60.左值右值以及类型判断
    59.C++与正则表达式
    57.C++处理转义字符
    56.lambda表达式与绑定以及伪函数和绑定
    55.函数模板指针匹配(模板自动匹配*多的)
    54.函数模板默认参数
    53.伪函数与函数绑定器
    52.模板的重载
    51.模板与引用
  • 原文地址:https://www.cnblogs.com/lzkwin/p/javascript_this.html
Copyright © 2011-2022 走看看