基本类型vue
• 空值(null) • 未定义(undefined) • 布尔值( boolean) • 数字(number) • 字符串(string) • 符号(symbol,ES6 中新增)
引用类型vuex
• 对象(object)
对于基本类型,赋值(=)是值的拷贝,比较(===)的是实际的值,而对于引用类型(Array也是一种Object),赋值(=)是引用地址的拷贝,比较(===)的是引用地址:segmentfault
注:下面图例中用相似于X000001,X000002表示引用地址,只为了更好的举例说明,并非真实的值数组
const a = '哈哈' const b = '哈哈' console.log(a === b) // true const c = {} const d = {} console.log(c === d) // false
注解:spa
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
注解:code
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
注解:blog
1.b = {...a}中,z是基本类型直接拷贝值,y和w是对象,是引用地址的拷贝 2.y是只操做属性,链接不会断开,w操做了自己,生产了一个新对象,链接断开(参考上面的总结)
案例四理解以后应该就知道为何js对象有浅拷贝和深拷贝的区分了图片
场景:目前有多个用户,每一个用户有本身的属性,展现而且能够修改
程序实现(例如vue)ip
判断两个对象值是否相等(只是纯值,无论引用地址)
https://segmentfault.com/a/11...