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

JS拷贝几种实现方法

1、使用递归(循环)的方式实现拷贝 //使用递归的方式实现数组、对象的深拷贝 function deepClone1(obj) { //判断拷贝的要进行深拷贝的是数组还是对象,是数组的话进行数组拷贝...,对象的话进行对象拷贝 //进行深拷贝的不能为空,并且是对象或者是 if (obj && typeof obj === "object") { var objClone = Array.isArray...objClone[key] = obj[key]; } } } return objClone; } return obj; } 2、lodash函数库实现拷贝...lodash很热门的函数库,提供了 lodash.cloneDeep()实现拷贝 3、通过 JSON 对象实现拷贝 //通过js的内置对象JSON来进行数组对象的深拷贝 function deepClone2...(并不深,一级拷贝) 当对象中只有一级属性,没有二级属性的时候,此方法为深拷贝,但是对象中有对象的时候,此方法,在二级属性以后就是浅拷贝

1.6K20

js拷贝拷贝

device-width, initial-scale=1.0"> Document 1234567891011// 在JS...中,数据类型分为基本数据类型和引用数据类型两种,对于基本数据类型来说,它的值直接存储在栈内存中, // 而对于引用类型来说,它在栈内存中仅仅存储了一个引用,而真正的数据存储在堆内存中// 当基本类型实现拷贝...// 当复杂类型实现拷贝,新对象与旧对象仍然同时指向堆内存的同一属性,互不独立,相互影响。...// 也就是说当我们创建新数组newArr时,赋予newArr的是arr在栈中的地址(指针), // 其实仍与旧数组arr共享同一个内存,所以修改新数组newArr后,旧数组arr也会被修改// 深拷贝...// 它可以将复杂类型的数据相互独立出来,互不影响 // 深拷贝不会拷贝引用类型的引用,而是将引用类型的值全部拷贝一份,形成一个新的引用类型, // 这样就不会发生引用错乱的问题,使得我们可以多次使用同样的数据

2.5K20

JS拷贝与浅拷贝

); 使用JSON.parse(JSON.stringify(arr))的方式进行深拷贝时,并不会拷贝函数。...使用 JSON.parse(JSON.stringify(arr)) 进行深拷贝的方式相对简单且易于理解,适合用于处理普通的数据结构。...MessageChannel 使用MessageChannel实现拷贝。 MessageChannel除了用作通信还有一些hack的用法,比如用它来做deepClone。...使用 MessageChannel 实现异步深拷贝,可以正确地处理任何类型的数据,包括特殊类型。 由于它是异步的方式,所以性能可能会受到一定影响,特别是在处理大型数据结构时会更明显。...slice() 方法不会修改原始数组,而是返回一个浅拷贝(shallow copy)的新数组。 slice() 方法可以接收两个参数,即 start 和 end。

7410

js拷贝与浅拷贝

1.区别: 深拷贝和浅拷贝的使用场景是在复杂对象里,即对象的属性还是对象; 浅拷贝是指只复制一层对象,当对象的属性是引用类型时,实质复制的是其引用,当引用指向的值改变时也会跟着变化;深拷贝是指复制对象的所有层级...2.深拷贝实现 Json序列化与反序列化: function deepClone(obj){ let _obj = JSON.stringify(obj), objClone =...不可枚举的属性会被忽略 对于引用类型:object,array,date,regexp,function,err,只能深拷贝对象和数组,对于其他种类的对象,会失真。...最佳实现:(类似lodash的cloneDeep) function isArray(val) { return Object.prototype.toString.call(val) ===...; } else { obj[property] = obj2[property]; } } return obj; } 3.浅拷贝实现

1.3K30

js库 - 浅拷贝 & 深拷贝

然后面试中经常会问、业务中也经常会遇到的问题就是深浅拷贝的问题了。 栈内存中简单数据类型直接拷贝就能得到一个副本,但是复杂数据类型的拷贝如果也想得到一个副本,就需要深拷贝了。...浅拷贝: var a = 1; var b = a; 这就是浅拷贝了,虽然你视觉上看上去a = b;但是修改b的值,a不会收影响。因为b是a的一个副本,就像你拷贝了一个文件夹副本一样。...修改副本,源文件夹不会受影响。...但这种拷贝情况只局限在简单类型的拷贝: string、number、boolean、null、undefiend 如果你拷贝一个数组/对象(以数组为例): var c = [1,2,3]; var d...深拷贝 具体深拷贝就是要理解了复杂类型拷贝的缺点,然后再进行弥补。 既然想要复杂类型也像简单类型那样拷贝一个新数据的话,就不单单是拷贝地址了。

2.1K30

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

1. object.assign object.assign 是 ES6 中 Object 的一个方法,该方法可以用于JS 对象的合并等多个用途,其中一个用途就是可以进行浅拷贝。...如果存在对象的嵌套,那么浅拷贝将无能为力。因此深拷贝就是为了解决这个问题而生的,它能解决多层对象嵌套问题,彻底实现拷贝。...深拷贝则不同,对于复杂引用数据类型,其在堆内存中完全开辟了一块内存地址,并将原有的对象完全复制过来存放。 深拷贝后的对象与原始对象是相互独立、不受影响的,彻底实现了内存上的分离。...总的来说,深拷贝的原理可以总结如下: 将原对象从内存中完整地拷贝出来一份给新对象,并从堆内存中开辟一个全新的空间存放新对象,且新对象的修改并不会改变原对象,二者实现真正的分离。 1....实现拷贝方法 下面是一个实现 deepClone 函数封装的例子,有几点需要注意下。

2.3K40

js拷贝与深拷贝

拷贝拷贝了基本类型数据和引用类型数据的指针,叫浅拷贝拷贝的对象里,如果没有引用类型的数据,可以使用浅拷贝,方便快捷。...如果有引用类型,那么存在被篡改的风险,更应该使用深拷贝拷贝方法 1、手撸一个浅拷贝函数 1function shallowClone(obj) { 2 const newObj = {};...("fx is a great girl") 10 } 11} 12var newObj = Object.assign({}, fxObj); 13 3、数组的slice、concat方法 深拷贝...完全拷贝了基本类型和引用类型内部所有数据,叫深拷贝拷贝方法 1、JSON暴力转换 1const obj2=JSON.parse(JSON.stringify(obj1)); 但是这种方式存在弊端,...hash.set(obj, cloneObj); 12 for (let key in obj) { 13 if (obj.hasOwnProperty(key)) { 14 // 实现一个递归拷贝

1.1K10

JS拷贝与浅拷贝

其实在工作写代码和面试中,会经常碰到这两个概念:深拷贝,浅拷贝。但今天的重点是深拷贝。 下面我将简单介绍下什么是深拷贝,浅拷贝?...今天的重点是深拷贝,浅拷贝没啥可讲的。 talk is cheap,show me the code! 上浅拷贝代码: function shallowCopy(obj) { if (!...3.观察obj3和obj1,可以知道利用JSON.stringify、JSON.parse实现的深拷贝,是可以实现拷贝的。 我们再给对象加多点属性,比如加个函数。...所以通过JSON.parse和JSON.stringify实现的深拷贝不完美。 那么我分享下我自己写的一个对象深拷贝的方法,这就是我个人比较常用的方案了。...obj88 Plus"; obj9.introduce(); obj9.brothers[0].introduce(); 运行结果: [deepCopy.png] 可以看到,我们的deepCopy函数是能够实现拷贝

2.1K10

js的深拷贝和浅拷贝

说到深拷贝与浅拷贝,为什么会有这两种概念呢,根本原因就在于js的两种数据类型:基本数据类型和引用数据类型,两种数据类型存储方式不同。...JavaScript 中变量的拷贝 js 中的拷贝区分为「浅拷贝」与「深拷贝」。 浅拷贝拷贝只会将对象的各个属性进行依次复制,并不会进行递归复制,也就是说只会赋值目标对象的第一层属性。...动手实现一份浅拷贝加扩展的函数 function _isPlainObject(target) { return (typeof target === 'object' && !!...通过循环来实现拷贝 function copy(arr){ var obj=arr.constructor==Array?...__proto__ = Object.create(null); for (let key in target) { // 相关操作 } 文章参考链接:js深浅拷贝知多少

1.4K20

搞定 JS 深浅拷贝

拷贝与深拷贝的区别 浅拷贝是创建一个新的对象,如果属性是基本类型,拷贝的就是基本类型的值,如果属性是引用类型,拷贝的就是内存地址。如果这个内存地址的值发生了变化,就会影响到其他的对象。...深拷贝是将一个对象从内存中完整拷贝一份出来,从内存中开辟一个新的区域放新对象,并且修改新对象不会影响原对象。 总而言之,浅拷贝只复制指向某个对象的指针,而不复制对象本身,新旧对象还是共享同一块内存。...,这里可以用 while 替代 for...in ,因为 while 比 for...in 遍历的速度快,现在就来实现一个迭代器 function forEach(array, iterate) {...2 ] } console.log('obj2', obj2) // obj2 { name: '小小鑫', arr: [ 1, [ 1, 2 ] ] } niceeeeeeeeee~ 首发自:搞定 JS...深浅拷贝 - 小鑫の随笔

74930
领券