call/apply用來改變函數的執行上下文(this),它們的第一個參數thisArg是個對象,即作為函數內的this。
多數時候你傳啥函數內就是啥。僅以call示例
function fun() { alert(this); } fun.call(1); fun.call('a'); fun.call(true); fun.call({name:'jack'});
分別彈出“1”、“a”、“true”、“[object Object]”。
有兩種情況需要注意,傳null或undefined時,將是JS執行環境的全局變量。瀏覽器中是window,其它環境(如node)則是global。
fun.call(null); // window or global fun.call(undefined); // window or global
這在ECMAScript5.1 15.3.4.4中有解釋,如下
嚴格模式下情況又有所不同,ES3比較寬容盡量去揣測代碼意圖。ES5嚴格模式(ie6/7/8/9除外)則不再揣測,給call/apply傳入的任何參數不再轉換。如下
'use strict' function fun() { alert(this); } fun.call(null) // null fun.call(undefined) // undefined
須注意!