1. 程式人生 > >JS JavaScript中的this

JS JavaScript中的this

bsp 運行時 模式 undefine sna 嚴格模式 his undefined var

this是JavaScript語言中的一個關鍵字

它是函數運行時,在函數體內部自動生成的一個對象,只能在函數體內部使用。

function test() {
 this.x = 1;
}

上面代碼中,函數test運行時,內部會自動有一個this對象可以使用。

那麽,this的值是什麽呢?

函數在不同使用場合,this有不同的值。總之,this就是函數運行時所在的環境對象。

情況一:純粹的函數調用

這是函數的最常通用法,屬於全局性調用,因此this就代表全局對象。

var x = 1;
function test() {
   console.log(this.x);
}
test();  
// 1

情況二:作為對象的方法調用

函數還可以作為某個對象的方法調用,這時this就指這個上級對象

function test() {
  console.log(this.x);
}

var obj = {};
obj.x = 1;
obj.m = test;

obj.m(); // 1

情況三:作為構造函數調用

構造函數就是通過這個函數可以生成一個新對象。這時,this就指這個新對象

function test() {
 this.x = 1;
}

var obj = new test();
obj.x // 1

為了表明這時this不是全局對象,下面代碼:

var x = 2;
function test() { this.x = 1; } var obj = new test(); x // 2

運行結果為2,表明全局變量x的值沒有變化

情況四:apply調用

apply()是函數的一個方法,作用是改變函數的調用對象。它的第一個參數就表示改變後的調用這個函數的對象。因此,這時this指的就是這個參數。

var x = 0;
function test() {
 console.log(this.x);
}

var obj = {};
obj.x = 1;
obj.m = test;
obj.m.apply() // 0

apply()的參數為空時,默認調用全局變量。因此,這時運行結果為0,證明this指的是全局對象。

如果把最後一行代碼修改成

obj.m.apply(obj); //1

運行結果就變成1,證明這時this代表的對象是obj

改變this的指向有以下幾種方法

使用ES6的箭頭函數

在函數內部_this=this

使用apply、call、bind

new實例化一個對象

其實this的指向,始終堅持一個原理:this永遠指向最後調用它的那個對象。

幾個例子:

例1:

    var name = "windowsName";
    function a() {
        var name = "Cherry";

        console.log(this.name);          // windowsName

        console.log("inner:" + this);    // inner: Window
    }
    a();
    console.log("outer:" + this)         // outer: Window

這裏我們沒有使用嚴格模式,如果使用嚴格模式的話,全局對象就是 undefined,那麽就會報錯 Uncaught TypeError: Cannot read property ‘name‘ of undefined

例2:

    var name = "windowsName";
    var a = {
        name: "Cherry",
        fn : function () {
            console.log(this.name);      // Cherry
        }
    }
    a.fn();

例3:

var name = "windowsName";
var a = {
    name: "Cherry",
    fn : function () {
        console.log(this.name);      // Cherry
     }
  }
window.a.fn();

例4:

    var name = "windowsName";
    var a = {
        // name: "Cherry",
        fn : function () {
            console.log(this.name);      // undefined
        }
    }
    window.a.fn();

例5:

    var name = "windowsName";
    var a = {
        name : null,
        // name: "Cherry",
        fn : function () {
            console.log(this.name);      // windowsName
        }
    }

    var f = a.fn;
    f();

為什麽不是 Cherry,這是因為雖然將 a 對象的 fn 方法賦值給變量 f 了,“this 永遠指向最後調用它的那個對象”,由於剛剛的 f 並沒有調用,所以 fn() 最後仍然是被 window 調用的。所以 this 指向的也就是 window。

例6:

    var name = "windowsName";

    function fn() {
        var name = ‘Cherry‘;
        innerFunction();
        function innerFunction() {
            console.log(this.name);      // windowsName
        }
    }

    fn()

JS JavaScript中的this