在嚴格模式下跃赚,全局作用域的函數(shù)中片部,this默認指向 undefined详囤, 這是嚴格模式所規(guī)定的。
// 非嚴格模式下
console.log(this); // Window
function doSomething(){
? ? console.log(this); // Window
}
doSomething(); // 這里可以看成window.doSomething()漓滔,所以函數(shù)里的this指向全局對象window
// 嚴格模式下
'use strict';
console.log(this); // Window
function doInStrict(){
? ? console.log(this); // undefined
}
doInStrict();
對象里的函數(shù),this指向該對象
var a = 1;
var obj = {
? ? a: 2,
? ? fn: function(){
? ? ? ? console.log(this); // {a: 2, fn: ?}
? ? ? ? console.log(this.a); // 2
? ? }
};
obj.fn();
上面函數(shù)被調(diào)用后乖篷,從打印結(jié)果可以看出此時 this 指向的是調(diào)用函數(shù)的對象 obj响驴。如果將對象中的函數(shù)賦給全局對象中定義的變量 fn1,執(zhí)行 fn1 又會出現(xiàn)什么結(jié)果呢撕蔼?
var a = 1;
var obj = {
? ? a: 2,
? ? fn: function(){
? ? ? ? console.log(this); // Winidow
? ? ? ? console.log(this.a); // 1
? ? }
};
var fn1 = obj.fn;
fn1(); // 可以看成window.fn1();
從上面的例子可以看出豁鲤,fn1 與 obj.fn 指向的函數(shù)是相同的,但是調(diào)用它的對象不同鲸沮,那么函數(shù)中 this 的指向也就不一樣了琳骡。
再看一個比較復(fù)雜的例子:
var a = 0;
function fn(){
consoloe.log(this.a);
}
var obj1 = {
a: 1,
fn: function(){
console.log(this.a);
}
};
var obj2 = {
a: 2,
fn: function(){
fn();
obj1.fn();
console.log(this.a);
}
}
obj2.fn();
先說下執(zhí)行結(jié)果,分別打印 0 1 2讼溺。當 obj2 調(diào)用 fn 函數(shù)時日熬,先執(zhí)行的是 fn(),這個函數(shù)是在全局作用域中定義的肾胯,該調(diào)用可以看成 window.fn()竖席,所以,該函數(shù)內(nèi)部的 this 指向的是 window 全局對象敬肚,this.a 自然就是全局對象中的 a 值(0)毕荐。
接著執(zhí)行的是 obj1.fn(),它會從 obj1 中找到 fn 函數(shù)并執(zhí)行艳馒。obj1 中的函數(shù) fn 執(zhí)行時調(diào)用它的對象是 obj1憎亚,所以,此時函數(shù)內(nèi)部的 this 指向的就是 obj1 自身弄慰。那么 this.a 查到的值也就是對象 obj1 中 a 的值(1)第美。
最后打印函數(shù)中 this 所處的函數(shù) fn 是被 obj2 調(diào)用的,那么自然而然 this 就指向了 obj2陆爽,所以 this.a 的結(jié)果就是 2 了什往。
從上面這個例子我們可以看出:函數(shù)內(nèi)部 this 指向跟調(diào)用函數(shù)的對象有關(guān),跟函數(shù)在哪里調(diào)用沒有關(guān)系慌闭。
Window內(nèi)置函數(shù)的回調(diào)函數(shù)中别威,this指向Window對象躯舔。
window 的內(nèi)置函數(shù)( setInterval setTimeout 等),其回調(diào)函數(shù)中的 this 指向的是window對象省古。
var name = 'window';
var obj = {
? ? name: 'obj',
? ? func: function(){
? ? ? ? setTimeout(function () {
? ? ? ? ? ? console.log(this.name) // window
? ? ? ? },1000)
? ? }
}
obj.func()
亞馬遜測評?www.yisuping.com