Wird die Gültigkeitskette von JavaScript bestimmt, wenn eine Funktion definiert oder aufgerufen wird?
欧阳克
欧阳克 2017-07-05 10:42:15
0
5
1244

Siehe das folgende Schließungsproblem

var x=10;
function fn() {
    console.log(x);
}

function show(f) {
    var x=20;

    (function() {
        f();
    })();
}
show(fn);

Es wird 10 statt 20 ausgegeben. Wenn x verwendet wird, wird dann nicht entlang der Gültigkeitsbereichskette nachgeschlagen? Wenn die Gültigkeitsbereichskette beim Erstellen der Funktion bestimmt wird, ist das Ergebnis 10. Wenn sie beim Erstellen der Funktion bestimmt wird aufgerufen, es sollte 20 sein. Ja Keine genaue Aussage über die Scope-Kette? Wie sollte hier die genaue Scope-Kette aussehen? Sind Fn und Show auf dem gleichen Niveau oder liegt Fn innerhalb von Show?

欧阳克
欧阳克

温故而知新,可以为师矣。 博客:www.ouyangke.com

Antworte allen(5)
学霸

作用域链是在函数定义的时候确定的.

在函数内定义的变量不能在函数之外的任何地方访问,因为变量仅仅在该函数的域的内部有定义。相对应的,一个函数可以访问定义在其范围内的任何变量和函数。换言之,定义在全局域中的函数可以访问所有定义在全局域中的变量。在另一个函数中定义的函数也可以访问在其父函数中定义的所有变量和父函数有权访问的任何其他变量。

https://developer.mozilla.org...

習慣沉默

作用域链是动态的,所以,在调用时确定。
但是你的这个代码中,闭包定义的function()是绑定的最外层的作用域
function所申明的函数默认是绑定的外层的作用域

(我也是在学习中。。。)

洪涛

在函数创建的时候创建一个包含全局变量对象的作用域链,储存在内部[[Scope]]属性中。函数执行的时候会创建一个执行环境,通过复制[[Scope]]属性中的对象,构建执行环境的作用域链,并把自己的活动对象推入该作用域链的前端以此形成完整的作用域链。[[Scope]]保存的是对全局变量的引用,而不是值的复制。

var a = 10;
function f(){
    console.log(a);
};
function foo(){
    a = 20;
    f();
};
foo() // 20;
阿神

闭包的调用方式和下面效果等价的,下面举得例子通过对比说明了,作用域链是和函数定义时位置相关的。

var x=10;
function fn(){
    console.log(x);
}
function show() {
    var x=20;
    fn();
}
show();  //输出10
-----------------------
var x=10;
function show() {
    var x=20;
    function fn(){
        console.log(x);
    }
    fn();
}
show();  //输出20

相关问题链接补充。/q/10...。有关于作用域链的讨论。

扔个三星炸死你

非严格模式任何IIFE的this指向都是window

以上文不对题。。。

Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage