静态作用域

js是遵循静态作用域的

词法作用域其实是指作用域在词法解析阶段既确定了,不会改变

基本类型
var foo = 1;

function sta() {
    console.log(foo);
}

(function () {
    var foo = 2;
    sta();
})();

// 打印出1 而不是 2

// 因为sta的scope在创建时,记录的foo是1。如果js是动态作用域,那么他应该弹出2

var foo = 1;

function sta() {
    console.log(foo);
}

(function () {
    foo = 2;
    sta();
})();

// 打印出2, 记录得foo依旧是全局变量, 只不过在其运行时, 已经变为2了

var foo = 1;

function sta() {
    console.log(foo);
}

(function () {
    sta();
    foo = 2;
})();

// 打印出1, foo改变发生在函数运行之后

引用类型
var obj = {foo1};
function sta() {
    console.log(obj.foo);
}

(function () {
    var obj = {foo2};
    sta();
})();

// 打印出1

var obj = {foo1};
function sta() {
    console.log(obj.foo);
}

(function () {
    obj.foo = 2;
    sta();
})();

// 打印出2

posted @ 2019-01-04 18:21  rencoo  阅读(292)  评论(0编辑  收藏  举报