手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >javascript连续赋值问题
javascript连续赋值问题
摘要:前几天在搜索面试题时发现了这么一段代码,执行完后感觉完全不与所想的一样vara={n:1};varb=a;a.x=a={n:2};conso...

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

var a = { n : 1 }; var b = a; a.x = a = {n : 2}; console.log(a.x); 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后边,这条赋值到底执行了什么就一目了然了.

javascript连续赋值问题1

这是语句执行时打印的log

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

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

javascript连续赋值问题2

以上所述就是本文的全部内容了,希望大家能够喜欢

【javascript连续赋值问题】相关文章:

javascript实现树形菜单的方法

javascript实现淡蓝色的鼠标拖动选择框实例

javascript检测两个数组是否相似

javascript实现table表格隔行变色的方法

javascript获取select值的方法分析

javascript实现删除前弹出确认框

JavaScript实现自动变换表格边框颜色

JavaScript AOP编程实例

javascript实现日期按月份加减

浅谈Javascript线程及定时机制

精品推荐
分类导航