首页 > 网站 > WEB开发 > 正文

关于一个js连续赋值问题之我见(词略穷,见谅)

2024-04-27 14:07:17
字体:
来源:转载
供稿:网友

关于一个js连续赋值问题之我见(词略穷,见谅)

前几天在搜索面试题时发现了这么一段代码,执行完后感觉完全不与所想的一样

1 var a = {2     n : 13 };4 var b = a;5 a.x = a = {n : 2};6 console.log(a.x);7 console.log(b.x);

输出结果为:

undefined

[object Object]

一开始以为语句应该是先给 a 赋值 {n : 2} , 然后再将 a.x 赋值 {n : 2} ;

但事实却不是那样,于是改动了一下代码,添加几条log

var test;var a = {    get test () {        console.log("call a get");        return test;    },    set test (value) {        console.log("call a set");        test = value;    }}var test2;var b = {    get test2 () {        console.log("call b get");        return test2;    },    set test2 (value) {        console.log("call b set");        test2 = value;    }}a.test = {    n : 1};b.test2 = a.test;console.log("begin");a.test.x = a.test = {n : 2};

这样,在begin后边,这条赋值到底执行了什么就一目了然了.

这是语句执行时打印的log

先触发了一次get,然后触发了一次set.

本人猜想,该条语句执行的顺序为,先将左边变量取出,然后执行赋值.(在执行该条语句前,先将对象引用取出,然后从右到左执行赋值)

上图来自 http://snandy.iteye.com/blog/785445

部分参考资料:

http://blog.csdn.net/kittyjie/article/details/8242523


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表