先写一段测试用例:
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"。
本文通过一个具体的测试用例,深入探讨了JavaScript中bind方法的工作原理。详细解释了bind如何创建新函数并改变this指向,以及新函数与原函数的关系。
先写一段测试用例:
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"。
转载于:https://www.cnblogs.com/douglasvegas/p/4807312.html

被折叠的 条评论
为什么被折叠?