美文网首页
js-转载原创-《js对象引用,深入理解》

js-转载原创-《js对象引用,深入理解》

作者: 杯雪1990 | 来源:发表于2019-06-10 11:43 被阅读0次

参考:
https://segmentfault.com/a/1190000014724227?utm_source=index-hottest

<meta charset="utf-8">

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都是一个新对象,方别指向不同的地址,所以不相等

[图片上传失败...(image-f08f26-1560137919280)]

案例二

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都会变化

[图片上传失败...(image-aa7541-1560137919280)]

案例三

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的联系,分别指向于不同的对象

[图片上传失败...(image-20bd95-1560137919280)]

总结:(精髓所在)

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

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

3,数组也是对象

案例四

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操作了本身,生产了一个新对象,连接断开(参考上面的总结)

面试题:

var a = {n: 1};
 var b = a; 
a = {n: 2};
a.x = a; 

/* 错误 
console.log(a.x);//{n:2, x: {n: 2}} 
console.log(b.x);//同上 
*/ 

// 正确答案,因为a直接指向了新对象,所以a和b的链接断开 
console.log(a.x);//{n:2, x: {n: 2, x: {n:2, x...}}}} 
console.log(b.x);//undefined

相关文章

  • js-转载原创-《js对象引用,深入理解》

    参考:https://segmentfault.com/a/1190000014724227?utm_source...

  • js-引用类型对象拷贝

    1.引用类型; 2.过滤数组; 3.深浅拷贝方法; 1.引用类型有哪些?非引用类型有哪些 引用类型:引用类型(Ob...

  • js-引用类型对象拷贝

    在JavaScript中,对于Object和Array这类引用类型值,当从一个变量向另一个变量复制引用类型值时,这...

  • JS面向对象精要(二)_函数

    JS面向对象精要(一)_原始类型和引用类型JS面向对象精要(二)_函数JS面向对象精要(三)_理解对象JS面向对象...

  • JS面向对象精要(三)_理解对象

    JS面向对象精要(一)_原始类型和引用类型JS面向对象精要(二)_函数JS面向对象精要(三)_理解对象JS面向对象...

  • JS面向对象精要(四)_构造函数和原型对象

    JS面向对象精要(一)_原始类型和引用类型JS面向对象精要(二)_函数JS面向对象精要(三)_理解对象JS面向对象...

  • JS面向对象精要(五)_继承

    JS面向对象精要(一)_原始类型和引用类型JS面向对象精要(二)_函数JS面向对象精要(三)_理解对象JS面向对象...

  • JS-引用类型与对象拷贝

    1.引用类型有哪些?非引用类型有哪些 基本类型值(数值、布尔值、字符串、null和undefined):指的是保存...

  • JS-对象

    一、数学对象(8) 二、字符串对象(9 ) 1、字符串:是一个字符2、字符串对象:是一个数组。3、用字符串方法对字...

  • JS-对象

    1. 基础 可通过字面量定义对象,在对象内部定义属性和方法 可以通过对象.属性或者对象['属性'] 对象['方法...

网友评论

      本文标题:js-转载原创-《js对象引用,深入理解》

      本文链接:https://www.haomeiwen.com/subject/fioaxctx.html