首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

JS 数组、对象的深拷贝

博客地址:https://ainyi.com/72 JavaScript 程序中,对于简单的数字、字符串可以通过 = 赋值拷贝 但是对于数组、对象、对象数组拷贝,就有浅拷贝和深拷贝之分 浅拷贝就是当改变了拷贝后的数据...a = [1, 2, 3] let b = a.slice(0) b.push(4) a // [1, 2, 3] b // [1, 2, 3, 4] concat() 数组方法 concat() 连接一个或多个数组...,并返回一个副本 那么不设置参数,就返回本数组 let a = [1, 2, 3] let b = a.concat() b.push(4) a // [1, 2, 3] b // [1, 2, 3,...a // { name: 'krry' } b // { name: 'lily' } --- 以上是简单数组、对象的深拷贝方法,但是对于二维数组、对象数组、对象里包含对象,以上方法均达不到深拷贝方法...以上只能达到数组、对象的第一层的==深拷贝==,对于里面的数组或对象属性则是==浅拷贝==,因为里面的内存地址只是拷贝了一份,但都是指向==同一个地址== 所以当改变数组、对象里的数组元素或对象,原数据依然会改变

8.1K30

14 个拷贝数组JS 技巧

console.log(copy); console.log(numbers); // 输出 // [1, 2, 3, 4, 5, 6] // [1, 2, 3, 4, 5] Array.of() 方法创建一个具有可变数量参数的新数组实例...Array.of() 和 Array 构造函数之间的区别在于处理整数参数:Array.of(7) 创建一个具有单个元素 7 的数组,而 Array(7) 创建一个长度为7的空数组(注意:这是指一个有7个空位...,就是数组是元素是对象的时候,咱们更改对象的值,另一个也会跟着变,就能技巧4来说,如果咱们的数组元素是对象,如下所示: const authors = [ { name: '前端', age: 25...authors ] copy[0].name = '被修改过的大龙' console.log(copy) console.log(authors) 所以上面的技巧适合简单的数据结构,复杂的结构要使用深拷贝...数组拷贝经常被误解,但这并不是因为拷贝过程本身,而是因为缺乏对 JS 如何处理数组及其元素的理解。

40630

JS手撕(二) 数组扁平化、浅拷贝、深拷贝

拷贝 如果我们给把一个对象直接赋值给另一个对象,那么我们修改其中的一个对象都会影响到另一个对象(非重新赋值),因为它们是同一个引用。...而拷贝的话,两个对象就不再是同一个引用了,所以修改对象不会影响到另一个对象。但是拷贝还分为浅拷贝和深拷贝两种。...浅拷贝拷贝就是只能拷贝第一层,如果有嵌套对象,那么嵌套对象是没法拷贝的,所以修改嵌套对象还是会影响到另一个对象。而在后面讲的深拷贝则是即使有嵌套对象,也能够正常拷贝全部的方法。...顺带一提:通过concat和slice可以浅拷贝数组。 深拷贝拷贝只能拷贝对象的第一层,如果遇到嵌套对象,又会变成对象的引用。这时候就可以使用深拷贝,深拷贝就是拷贝整个对象,而不仅仅是第一层。...面试官连环追问:数组拍平(扁平化) flat 方法实现 - 掘金 (建议精读)原生JS灵魂之问(中),检验自己是否真的熟悉JavaScript? - 掘金

1.2K10

js数组拷贝赋值复制-你真的懂?

在看react-native性能优化的时候,看到如何避免shouldComponentUpdate的异常数据时,脑内一阵风暴,从而牵连出一连串的问题,于是有了这一篇关于js数组的复制(深浅拷贝)与赋值等为何能产生异常数据的文章...一、push与concat push的定义是:像数组末尾添加一个或更多元素,并返回新的长度。该方法会改变数组的长度。...concat的定义是:连接两个或更多的数组,并返回结果,该方法不会改变现有数组,而仅仅会返回数组一个副本。...你传递一个对象(在js数组不是简单数据类型,而是对象)到一个函数,如果在函数里面改变了这个参数的内容,在外部这个变化是可见的。...2.深拷贝 (1)slice 函数 (2)concat 函数 (3)assgin 三个函数的原理都是返回数组一个副本(相当于另外开辟内存空间),所以并不会改变数组本身的的值 但是这里有一点不同,就是assgin

4.7K30

js拷贝拷贝

device-width, initial-scale=1.0"> Document 1234567891011// 在JS...中,数据类型分为基本数据类型和引用数据类型两种,对于基本数据类型来说,它的值直接存储在栈内存中, // 而对于引用类型来说,它在栈内存中仅仅存储了一个引用,而真正的数据存储在堆内存中// 当基本类型实现浅拷贝...,arr被分配到了堆内存中,在栈内存留下可以寻找到的指针, // 也就是说当我们创建新数组newArr时,赋予newArr的是arr在栈中的地址(指针), // 其实仍与旧数组arr共享同一个内存,所以修改新数组...newArr后,旧数组arr也会被修改// 深拷贝 // 它可以将复杂类型的数据相互独立出来,互不影响 // 深拷贝不会拷贝引用类型的引用,而是将引用类型的值全部拷贝一份,形成一个新的引用类型, //...2、 function deepClone(target) { // 定义一个变量 let result; // 如果当前需要深拷贝的是一个对象的话更多内容请见原文,原文转载自:http://www.mark-to-win.com

2.5K20

js数组深度拷贝 的四种实现方法

------------------------------------------------------------------ var ary1=[1,2]; es5: //方法一:适用 单层 数组嵌套的深拷贝...var ary2 = ary1.concat(); //方法二:适用 多层 数组嵌套的深拷贝 var ary2 = JSON.parse(JSON.stringify(ary1));   //此方法适用于...Oject的深度拷贝,因为Array属于Oject类型,所以也适用于此处;   //需要注意的是:作为Oject的深度拷贝时,要复制的function会直接消失,所以这个方法只能用在单纯只有数据的对象。...es6: // 方法三:适用 单层 数组嵌套的深拷贝 var ary2 = [...ary1]; // 方法四:适用 单层 数组嵌套的深拷贝 var [...ary2] = ary1; //方法五:通过递归实现...多层 的深拷贝 function deepCopy(source){ if (typeof source !

56020

JS拷贝与深拷贝

因为对象是引用类型,所以赋值时的操作仅是赋予相同的地址,当对其中一个对象进行操作时,就会影响其他的对象。解决这个问题就需要使用拷贝了。...拷贝的方式分两种: 浅拷贝 基本类型:拷贝值 引用类型:拷贝对象引用。 深拷贝 基本类型:拷贝值 引用类型:会创建一个新的引用,将之前的对象完整的拷贝一份出来,并添加至新的引用当中。...这种比较试适合简单的单个数组或者对象使用,简单又方便 #深拷贝 #JSON.stringify() 如果要拷贝的对象中包含对象,就需要深拷贝了,一般使用原生的方法JSON.parse(JSON.stringify...指向的是当前类本身 hash.set(obj, cloneObj); for (let key in obj) { if (obj.hasOwnProperty(key)) { // 实现一个递归拷贝...如何写出一个惊艳面试官的深拷贝?

1.6K20

js库 - 浅拷贝 & 深拷贝

但这种拷贝情况只局限在简单类型的拷贝: string、number、boolean、null、undefiend 如果你拷贝一个数组/对象(以数组为例): var c = [1,2,3]; var d...这个副本d的地址改变,对c没有影响,而你给d重新指向一个新的数组,就是改变地址了。此时只有d指向了新数组[5,6,7],但是c不受影响,所以打印出来的不变。 但是虽然有两个地址,一个是原、一个是副本。...可他们同时指向同一个堆内存的数据。 这样看来,你拷贝出来的d和c用的是同一个数组。 所以d.push执行以后,并不是c也跟着push了,而是c指向的数组和被d.push的是同一个数组。...对于函数,新建一个function,然后拷贝 对于数组,新建一个数组,然后 forEach 遍历拷贝。...如果循环过程中,数组中嵌套复杂类型,再次递归调用深拷贝方法。 对于对象,新建一个对象,然后for in遍历拷贝非原型值。如果循环过程中,对象中嵌套复杂类型,再次递归调用深拷贝方法。

2K30

js拷贝与浅拷贝

1.区别: 深拷贝和浅拷贝的使用场景是在复杂对象里,即对象的属性还是对象; 浅拷贝是指只复制一层对象,当对象的属性是引用类型时,实质复制的是其引用,当引用指向的值改变时也会跟着变化;深拷贝是指复制对象的所有层级...JSON.parse(_obj); return objClone }  缺点: 非数组对象的属性不能保证以特定的顺序出现在序列化后的字符串中。...undefined、任意的函数以及 symbol 值,在序列化过程中会被忽略(出现在非数组对象的属性值中时)或者被转换成 null(出现在数组中时)。...不可枚举的属性会被忽略 对于引用类型:object,array,date,regexp,function,err,只能深拷贝对象和数组,对于其他种类的对象,会失真。...这种方法比较适合平常开发中使用,因为通常不需要考虑对象和数组之外的类型。

1.3K30

JS专栏】JS对象的浅拷贝与深拷贝

1. object.assign object.assign 是 ES6 中 Object 的一个方法,该方法可以用于JS 对象的合并等多个用途,其中一个用途就是可以进行浅拷贝。...3. concat 拷贝数组 数组的 concat 方法其实也是浅拷贝,所以连接一个含有引用类型的数组时,需要注意修改原数组中的元素的属性,因为它会影响拷贝之后连接的数组。...不过 concat 只能用于数组的浅拷贝,使用场景比较局限。...slice 方法会返回一个新的数组对象,这一对象由该方法的前两个参数来决定原数组截取的开始和结束位置,是不会影响和改变原始数组的。但是,数组元素是引用类型的话,也会影响到原始数组。...我们总结一下浅拷贝的原理: 对基础类型做一个最基本的一个拷贝; 对引用类型开辟一个新的存储,并且拷贝一层对象属性。

2.3K40

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券