Javascript: unique inner function "remembers" outer function first call arguments?
Javascript: unique inner function "remembers" outer function first call arguments?
使用此代码
this.outerFn = function(param)
{
this.currentParam = param;
if(!this.hasInnerFn)
{
this.innerCallFn = function()
{
console.log('param: ' + param.toString() + ' ; this.currentParam: ' + this.currentParam);
}
this.hasInnerFn = true;
}
setTimeout(function(){
this.innerCallFn();
},1000)
}
并调用:
this.outerFn('param 1')
this.outerFn('param 2')
给出以下结果:
param: param 1 ; this.currentParam = param 1
param: param 1 ; this.currentParam = param 2
为什么在第二次调用 innerCallFn
时它引用了外部函数的第一个参数?
innerCallFn
只创建一次,所以它不会在第一次调用时只看到它的值 'param'
吗?
换句话说,每个函数调用都有自己的闭包吗?
内部函数使用的 param
的值确实在首次创建该函数时仅绑定一次。
使用此代码
this.outerFn = function(param)
{
this.currentParam = param;
if(!this.hasInnerFn)
{
this.innerCallFn = function()
{
console.log('param: ' + param.toString() + ' ; this.currentParam: ' + this.currentParam);
}
this.hasInnerFn = true;
}
setTimeout(function(){
this.innerCallFn();
},1000)
}
并调用:
this.outerFn('param 1')
this.outerFn('param 2')
给出以下结果:
param: param 1 ; this.currentParam = param 1
param: param 1 ; this.currentParam = param 2
为什么在第二次调用 innerCallFn
时它引用了外部函数的第一个参数?
innerCallFn
只创建一次,所以它不会在第一次调用时只看到它的值 'param'
吗?
换句话说,每个函数调用都有自己的闭包吗?
内部函数使用的 param
的值确实在首次创建该函数时仅绑定一次。