javascript中的this做用域详解

javascript中的this做用域详解

Javascript中this的指向一直是困扰我好久的问题,在使用中出错的机率也很是大。在面向对象语言中,它表明了当前对象的一个引用,而在js中却常常让我以为混乱,它不是固定不变的,而是随着它的执行环境的改变而改变。
在Javascript中this老是指向调用它所在方法的对象。由于this是在函数运行时,自动生成的一个内部对象,只能在函数内部使用。javascript

下面咱们分几种状况深刻分析this的用法:
1.全局的函数调用java

function globalTest() {
        this.name = "global this";
        console.log(this.name);
    }
    globalTest(); //global this

以上代码中,globalTest()是全局性的方法,属于全局性调用,所以this就表明全局对象window。为了充分证实this是window,对代码作以下更改:数组

var name = "global this";

    function globalTest() {
        console.log(this.name);
    }
    globalTest(); //global this

name做为一个全局变量,运行结果仍然是“global this”,说明this指向的是window。在方法体中咱们尝试更改全局name,再次调用方法输出“rename global this”, 说明全局的name在方法内部被更改。代码以下:app

var name = "global this";

    function globalTest() {
        this.name = "rename global this"
        console.log(this.name);
    }
    globalTest(); //rename global this

根据以上三段代码,咱们得出结论:对于全局的方法调用,this指向的是全局对象window,即调用方法所在的对象。函数

2.对象方法的调用
若是函数做为对象的方法调用,this指向的是这个上级对象,即调用方法的对象。 在如下代码中,this指向的是obj对象。this

function showName() {
        console.log(this.name);
    }
    var obj = {};
    obj.name = "ooo";
    obj.show = showName;
    obj.show(); //ooo


3.构造函数的调用
构造函数中的this指向新建立的对象自己。code

function showName() {
        this.name = "showName function";
    }
    var obj = new showName();
    console.log(obj.name); //showName function

上述代码中,咱们经过new关键字建立一个对象的实例,new关键字能够改变this的指向,将这个this指向对象obj。
咱们再增长一个全局的name,用以证实this指向的不是global:对象

var name = "global name";

    function showName() {
        this.name = "showName function";
    }
    var obj = new showName();

    console.log(obj.name); //showName function
    console.log(name); //global name

在构造函数的内部,咱们对this.name进行赋值,但并无改变全局变量name。blog

4.apply/call调用时的this
apply和call都是为了改变函数体内部的this指向。 其具体的定义以下:
call方法:
语法:call(thisObj,Object)
定义:调用一个对象的一个方法,以另外一个对象替换当前对象。
说明:
call 方法能够用来代替另外一个对象调用一个方法。call 方法可将一个函数的对象上下文从初始的上下文改变为由 thisObj 指定的新对象。
若是没有提供 thisObj 参数,那么 Global 对象被用做 thisObj。ip

apply方法:
语法:apply(thisObj,[argArray])
定义:应用某一对象的一个方法,用另外一个对象替换当前对象。
说明:
若是 argArray 不是一个有效的数组或者不是 arguments 对象,那么将致使一个 TypeError。
若是没有提供 argArray 和 thisObj 任何一个参数,那么 Global 对象将被用做 thisObj, 而且没法被传递任何参数。

var value = "Global value";

    function FunA() {
        this.value = "AAA";
    }

    function FunB() {
        console.log(this.value);
    }
    FunB(); //Global value 由于是在全局中调用的FunB(),this.value指向全局的value
    FunB.call(window); //Global value,this指向window对象,所以this.value指向全局的value
    FunB.call(new FunA()); //AAA, this指向参数new FunA(),即FunA对象

    FunB.apply(window); //Global value
    FunB.apply(new FunA()); //AAA

在上述代码中,this的指向在call和apply中是一致的,只不过是调用参数的形式不同。call是一个一个调用参数,而apply是调用一个数组。具体的会在之后的博文中单独阐述。

相关文章
相关标签/搜索