JavaScript中的连续赋值问题实例分析
2019-07-12 08:36
1561 查看
本文实例讲述了JavaScript中的连续赋值问题。分享给大家供大家参考,具体如下:
JavaScript中的连续赋值:
<script> var a = {n: 1} var b = a; a.x = a = {n: 2} console.log(a.x);//undefined console.log(b.x)//Object {n: 2} </script>
Javascript中赋值运算符“=”的优先级是除了“,”以外最低的,并且是从右向左结合的。
Javascript中运算的顺序是从左向右的。
a.x = a = {n: 2}
可以看做a.x =(a = {n: 2})
,先运算a.x,在a中添加x属性,结果为null,在计算表达式(a = {n: 2})
,最后进行赋值运算。
修改程序:
<script> var a = {n: 1} var b = a; a = a.x = {n: 2} console.log(a.x);//undefined console.log(b.x)//Object {n: 2} </script>
<script> var a = {x:{xx:1},y:2,z:3}; var b = a.x; //{xx:1} var c = a; a.w = a.x.xx = a.y = a = {x:10,y:20}; console.log(a); console.log(b); console.log(c); </script>
运行结果:
a : {x: 10, y: 20}
b : {xx : {x: 10, y: 20}}
c :?{x:{xx:{x:10,y:20}},y:{x:10,y:20},z:3,w:{x:10,y:20}}
<script> console.log(c.x.xx.x);//10 console.log(c.y.x);//10 console.log(c.w.x);//10 </script>
上述代码感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试运行结果。
更多关于JavaScript相关内容还可查看本站专题:《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
您可能感兴趣的文章:
相关文章推荐
- 深入JavaScript:词法分析、连续赋值猜想
- javascript连续赋值问题
- javascript作用域问题实例分析
- javascript作用域问题实例分析
- JavaScript对象拷贝与赋值操作实例分析
- javascript连续赋值问题
- DirectShow 在vs2005中的问题解决之实例分析
- 关于递归超时问题的实例分析
- ASP.NET中关于Javascript给TextBox赋值丢失问题解决
- javascript动画、运动算法详细解释与分析 (二、javascript动画 时间精度问题)
- android listview 连续调用 getview问题分析及解决。
- javascript 连续赋值(转载)
- javascript:void(0)的真正含义实例分析
- javascript中的prototype属性实例分析说明
- [转]android listview 连续调用 getview问题分析及解决。
- javaScript中连续赋值运算
- [javascript]通过js获取cookie的实例及简单分析
- Js(JavaScript)中,弹出是或否的选择框示例(confirm用法的实例分析)
- CSS, HTML, JavaScript等兼容性问题案例分析及解决
- Javascript 浮点运算精度问题分析与解决