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 的值确实在首次创建该函数时仅绑定一次。