通过实例了解JS 连续赋值
2019-09-24 14:30
1366 查看
这篇文章主要介绍了通过实例了解JS 连续赋值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
问题:
var a = {n: 1}; var b = a; a.x = a = {n: 2}; console.log(a.x); //undfined console.log(b.x); //{a:2}
根据js引擎语法解析,会先去从左到右寻找有没有未声明的变量,如果有就把该变量提升至作用域顶部并声明该变量。那么恭喜js引擎他找到a.x这个属性没有声明,那么他会在{n: 1}这个内存区声明一个x属性等待赋值!
语法解析完成后,开始进行运算(ps:赋值运算),首先将a变量的指针指向了一个新的内存区{n: 2},那么a变量脱离了对内存区{n: 1}的引用关系。
但是此时{n:1 }这个内存区并没有被GC回收因为b变量的指针依然指向它。并且因为之前就声明了x属性所以该内存区
增加了X属性。那么X属性指向哪儿呢?a.x = a = {n: 2}它的返回值就是{n: 2}的内存区。
那么根据图上可得:
a.x 不存在,故: => undefined
b.x => {n: 2}
以上就是本文的全部内容,希望对大家的学习有所帮助
您可能感兴趣的文章:
相关文章推荐
- 通过实例了解如何使用js获取下拉列表框内的值
- 通过实例了解js函数中参数的传递
- 转载:写了10年Javascript未必全了解的连续赋值运算 --> 说明了JS中变量是引用
- js中变量的连续赋值(实例讲解)
- 写了12年JS也未必全了解的连续赋值运算
- js引用类型指针及js连续赋值
- domino901通过js给复选框赋值,文档保存后,没按多值显示的处理方法
- This其实不难,通过实例全面解析JS中的This
- TextBox 禁止客户端输入 前台通过JS赋值 并在后台获取
- TextBox服务器控件只读设置并且能保存内容(通过js赋值的情况)
- 通过实例来了解PHP中的persistent resource和non persistent resource
- js方法名通过参数传递调用实例
- 通过js控制时间,一秒一秒自己动的实例
- 3.通过AES加密实例(基于c和oc)进一步了解指针
- 写了10年Javascript未必全了解的连续赋值运算
- 如何用反射创建实力对象?如何通过反射为上一个实例对象的x属性重新赋值为?
- 通过自定义特性,使用EF6拦截器完成创建人、创建时间、更新人、更新时间的统一赋值(了解下EF不常见的技术点)
- 通过实例解析js简易模块加载器
- js连续赋值与求值顺序,应用场景举例
- js执行的堆栈赋值实例详解(ES5)