zoukankan      html  css  js  c++  java
  • 关于一个js连续赋值问题之我见(词略穷,见谅)

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

    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

  • 相关阅读:
    修改centos7 DNS
    group by
    Oracle 删除表空间
    Oralce查看sid 、service_name
    Mysql修改lower_case_table_names
    Oralce静默安装
    Linux安装Mysql
    dbvisualier破解及使用
    Oracle扩容表空间
    lvm方式挂载盘及扩容
  • 原文地址:https://www.cnblogs.com/jiasm/p/4629381.html
Copyright © 2011-2022 走看看