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

简介: 前几天在搜索面试题时发现了这么一段代码,执行完后感觉完全不与所想的一样 1 var a = { 2 n : 1 3 }; 4 var b = a; 5 a.x = a = {n : 2}; 6 console.

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

1 var a = {
2     n : 1
3 };
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

 

目录
相关文章
|
16天前
|
JavaScript 前端开发 开发者
混淆赋值运算符(=)和相等比较运算符(==, ===)(js的问题)
混淆赋值运算符(=)和相等比较运算符(==, ===)(js的问题)
|
26天前
|
JavaScript 前端开发
js开发:请解释什么是ES6的解构赋值(destructuring assignment),并给出一个示例。
ES6的解构赋值简化了JavaScript中从数组和对象提取数据的过程。例如,`[a, b, c] = [1, 2, 3]`将数组元素赋值给变量,`{name, age} = {name: '张三', age: 18}`则将对象属性赋值给对应变量,提高了代码的可读性和效率。
|
1月前
|
JavaScript 前端开发
javascript中的解构赋值
javascript中的解构赋值
|
2月前
|
JavaScript 前端开发 网络架构
掌握JavaScript中的解构赋值:深入挖掘隐藏的技巧
掌握JavaScript中的解构赋值:深入挖掘隐藏的技巧
22 0
|
3月前
|
JavaScript 前端开发
如何巧妙使用`Object.keys`方法将`JS`的一个对象的特定的值赋值给另外一个对象
如何巧妙使用`Object.keys`方法将`JS`的一个对象的特定的值赋值给另外一个对象
16 0
|
4月前
|
JavaScript 前端开发
JavaScript高级主题:什么是 ES6 的解构赋值?
JavaScript高级主题:什么是 ES6 的解构赋值?
22 0
|
4月前
|
JavaScript 前端开发
JavaScript开发中ES6+新特性:使用解构赋值的好处是什么?
JavaScript开发中ES6+新特性:使用解构赋值的好处是什么?
47 2
|
8月前
|
JavaScript
SVG JS 动态赋值
SVG JS 动态赋值
62 0
|
9月前
|
前端开发 JavaScript 算法
ChatGPT工作提效之layedit上传多附件的解决方案(layedit赋值、layui.js底层修改、追加模式多附件上传)
ChatGPT工作提效之layedit上传多附件的解决方案(layedit赋值、layui.js底层修改、追加模式多附件上传)
172 0
|
9月前
|
JSON JavaScript 前端开发
javascript对象数据合并实现补齐24小时时间段同时赋值0的解决方案
javascript对象数据合并实现补齐24小时时间段同时赋值0的解决方案
94 0