资讯专栏INFORMATION COLUMN

深入理解js对象的引用

hedge_hog / 747人阅读

JavaScript 有七种内置类型,其中:

基本类型

• 空值(null)
• 未定义(undefined)
• 布尔值( boolean)
• 数字(number)
• 字符串(string)
• 符号(symbol,ES6 中新增)

引用类型

• 对象(object)

对于基本类型,赋值(=)是值的拷贝,比较(===)的是实际的值,而对于引用类型(Array也是一种Object),赋值(=)是引用地址的拷贝,比较(===)的是引用地址:

注:下面图例中用类似于X000001,X000002表示引用地址,只为了更好的举例说明,并不是真实的值

案例一
const a = "哈哈"
const b = "哈哈"
console.log(a === b) // true

const c = {}
const d = {}
console.log(c === d) // false

注解:

1.a和b是字符串,比较的是值,完全相等
2.c和d是对象,比较的是引用地址,c和d都是一个新对象,方别指向不同的地址,所以不相等

案例二
let a = { z: 5, y: 9 }
let b = a
b.z = 6
delete b.y
b.x = 8 
console.log(a) // {z: 6, x: 8}
console.log(a === b) // true

注解:

1.a是对象,b=a是将a的引用地址赋值给b
2.a和b都指向与同一个对象,修改这个对象,a和b都会变化

案例三
let a = { z: 5 }
let b = a
b = {z: 6}
console.log(a.z) // 5
console.log(a === b) // false

注解:

1.a是对象,b=a是将a的引用地址赋值给b
2.b = {z: 6}新对象赋值给b,切断了a和b的联系,分别指向于不同的对象

总结:(精髓所在)

只操作(修改,删除,添加)对象的属性,不会与之前对象断开连接(案例二)

直接操作对象本身,也就是最外层,会和之前的对象断开连接(案例三)

数组也是对象

案例四
let a = { z: 5, y: {x: 8}, w: {r: 10} }
let b = {...a}
b.z = 6
b.y.x = 9
b.w = {r: 11}
console.log(a) // { z: 5, y: {x: 9}, w: {r: 10}}
console.log(a.y === b.y) // true
console.log(a.w === b.w) // false
console.log(a === b) // false

注解:

1.b = {...a}中,z是基本类型直接拷贝值,y和w是对象,是引用地址的拷贝
2.y是只操作属性,连接不会断开,w操作了本身,生产了一个新对象,连接断开(参考上面的总结)


案例四理解之后应该就知道为什么js对象有浅拷贝和深拷贝的区分了

应用

场景:目前有多个用户,每个用户有自己的属性,展示并且可以修改
程序实现(例如vue)

首先我们将每一个用户都封装成一个多带带的模块(.vue),用户初始数据存放在model里面(vuex)

一般来说修改model里面数据,都需要用它的mutations和actions里面的方式,如果用户属性比较多,每一项都需要去定义一个mutations或actions的话,那开发量是相当的大

利用对象的引用关系,传过来的数据不和源对象,切断关系,是直接可以操作源对象,组件与组件之间的通信也可以这个实现

有利也有弊,这种操作起来很简单,但一旦切断他们的联系之后,不好维护,用这种方式需要对对象引用有深入的理解,知道什么时候会断开联系

个人建议只在这种多个相同组件中使用。

附加福利

判断两个对象值是否相等(只是纯值,不管引用地址)
https://segmentfault.com/a/11...

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/94723.html

相关文章

  • 深入理解JS深浅拷贝

    摘要:深拷贝相比于浅拷贝速度较慢并且花销较大。所以在赋值完成后,在栈内存就有两个指针指向堆内存同一个数据。结果如下扩展运算符只能对一层进行深拷贝如果拷贝的层数超过了一层的话,那么就会进行浅拷贝那么我们可以看到和展开原算符对于深浅拷贝的结果是一样。 JS中数据类型 基本数据类型: undefined、null、Boolean、Number、String和Symbol(ES6) 引用数据类型:...

    JackJiang 评论0 收藏0
  • 深入理解 Javascript 之 JS深浅拷贝

    摘要:动手实现深拷贝利递归来实现对对象或数组的深拷贝。递归思路对属性中所有引用类型的值进行遍历,直到是基本类型值为止。深拷贝只对对象自有属性进行拷贝测试数据拷贝方式其实也是一种继承的方式,当然继承还是有其他方法的感谢支持 深浅拷贝 基本类型 & 引用类型 ECMAScript中的数据类型可分为两种: 基本类型:undefined,null,Boolean,String,Number,Symb...

    Tikitoo 评论0 收藏0
  • 由ES规范学JavaScript(二):深入理解“连等赋值”问题

    摘要:有这样一个热门问题其实这个问题很好理解,关键要弄清下面两个知识点引擎对赋值表达式的处理过程赋值运算的右结合性一赋值表达式形如的表达式称为赋值表达式。赋值表达式是右结合的。 有这样一个热门问题: var a = {n: 1}; var b = a; a.x = a = {n: 2}; alert(a.x); // --> undefined alert(b.x); // --> {n: ...

    JasonZhang 评论0 收藏0
  • 深入理解 JavaScript中变量、值、传参

    摘要:所以说在中,也并不是一切都是对象原始类型值不可变原始类型的变量的值是不可变的,只能给变量赋予新的值。可以理解基本类型的变量的值,就是字面上写的数值。有四个变量图调用是传参,内层的会屏蔽外层的。图内层的的值被改变成的值被改变为。 showImg(https://segmentfault.com/img/bVbldfK); 1. demo 如果你对下面的代码没有任何疑问就能自信的回答出输出...

    endiat 评论0 收藏0
  • JavaScript中闭包

    摘要:闭包引起的内存泄漏总结从理论的角度将由于作用域链的特性中所有函数都是闭包但是从应用的角度来说只有当函数以返回值返回或者当函数以参数形式使用或者当函数中自由变量在函数外被引用时才能成为明确意义上的闭包。 文章同步到github js的闭包概念几乎是任何面试官都会问的问题,最近把闭包这块的概念梳理了一下,记录成以下文章。 什么是闭包 我先列出一些官方及经典书籍等书中给出的概念,这些概念虽然...

    HmyBmny 评论0 收藏0

发表评论

0条评论

hedge_hog

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<