先寫一段測試用例:
function tt()
{
alert(arguments.callee == tt);
alert(this);
}
var i = "1";
var i1 = tt.bind(i);
window.i1();
根據輸出,我的理解是:函數經過bind后,會生成一個本地函數i1,i1里會有一個對函數tt的引用,並非函數tt的一個副本,所以第一個alert會輸出true;
而函數一旦經過bind,即便指定了調用者,那么this仍然是bind指定的this,也就是"1"。