js赋值与优先级问题

        function test() {
            var a = { 
                n: 1
            };
            var b = a;
            a.x = a = {n: 2};
            console.log(a.x); //undefined
            console.log(b.x); //{n:2}
            console.log(a)
        }
        test()

a.x是属性访问,优先级比较高,那么赋值的话先把{n:2}赋给a,a的地址变化,那么a.x中的a不是地址也变了吗,在把{n:2}赋给a.x为何a.x还是undefined

阅读 2.9k
4 个回答
a.x = a = {n: 2};

这一句中, a.x 最先“地址求值”,这时 a 还没变,后面 a={n: 2} 时, a 已经变了(这时, a.x (的引用) 已经跟 a (的引用)完全是两个东西了,所以你只能在旧的 b 中看到它)。

你想要的效果是这样的吧,

function test() {
    debugger;
    var a = {
        n: 1
    };
    var b = a;
    a.x = a.n= 2;
    console.log(a.x); 
    console.log(b.x);
    console.log(a)
}
test()

});

推荐问题
宣传栏