首先我們要了解:
全域性變數預設是掛載在window下
一般情況this指向它的排程者
es6箭頭函式中 this指向它的建立者 而不是排程者
this遇到的情況
var name = 'this is window'; //定義window的name屬性
function getname()
getname();
var name = 'this is window'; //定義window的name屬性,看this.name是否會呼叫到
var testobj =
} testobj.getname();
function newobj()
new newobj
var name = "this is window"; //定義window的name屬性,看this.name是否會呼叫到
var testobj =
handle();
} }
testobj.getname();
var name = 'this is window'; //定義window的name屬性,看this.name是否會呼叫到
var testobj1 =
}var testobj2 =
testobj1.getname.call(testobj2);
[1] call( thisarg [,arg1,arg2,… ] ); // 第2個引數使用引數列表:arg1,arg2,...
this指向問題
一 this的指向在函式定義的時候是確定不了的,只有函式執行的時候才能確定this到底指向誰,實際上this的最終指向的是那個呼叫它的物件 例項一 函式this指向 function a a undefined windowwindow.a undefined window 解釋 這裡的a函式指向的...
this指向問題
在普通的函式中this指向window 在定時器中指向window,其實普通的函式和定時器都是window下的方法,所以都指向window 在乙個物件中的方法中this批向當前物件 new了 綁事件是事件源 真正觸發的 function fn a,b var aa fn.call 普通模式下this...
this指向問題
但是有時候這樣的判斷並不準確,可以按照如下規則進行判斷。瀏覽器環境 無論是否在嚴格模式下,在全域性執行環境中 在任何函式體外部 this 都指向全域性物件window node 環境 無論是否在嚴格模式下,在全域性執行環境中 在任何函式體外部 this 都是空物件 如果是new繫結並且 建構函式返回...