学习一下vuex的deepCopy源码 https://github.com/vuejs/vuex/blob/dev/src/util.js#L22 注释 我直接把第29行用的find函数放到里面了..., 这样好看一点 /** * 深拷贝 * @param {*} obj 拷贝对象(object or array) * @param {*} cache 缓存数组 */ function deepCopy...== 'object') { return obj } // 如果传入的对象与缓存的相等, 则递归结束, 这样防止循环 /** * 类似下面这种 * var a = {b...obj is hit, it is in circular structure 一开始没理解什么是循环结构, 后来在MDN的一个文章中看到了, 就类似于下图这样的循环结构 ?...image 深拷贝的另一个简单的方法 直接使用JSON.parse(JSON.stringify(Object))来进行 缺点: 如果对象或者数组里有函数什么的, 就会出问题啦 ?
device-width, initial-scale=1.0"> Document 1234567891011// 在JS...// 当复杂类型实现浅拷贝,新对象与旧对象仍然同时指向堆内存的同一属性,互不独立,相互影响。..., // 也就是说当我们创建新数组newArr时,赋予newArr的是arr在栈中的地址(指针), // 其实仍与旧数组arr共享同一个内存,所以修改新数组newArr后,旧数组arr也会被修改// 深拷贝...// 它可以将复杂类型的数据相互独立出来,互不影响 // 深拷贝不会拷贝引用类型的引用,而是将引用类型的值全部拷贝一份,形成一个新的引用类型, // 这样就不会发生引用错乱的问题,使得我们可以多次使用同样的数据...2、 function deepClone(target) { // 定义一个变量 let result; // 如果当前需要深拷贝的是一个对象的话更多内容请见原文,原文转载自:http://www.mark-to-win.com
对于字符串类型,浅复制是对值的复制,对于对象来说,浅复制是对对象地址的复制,并没 有开辟新的栈,也就是复制的结果是两个对象指向同一个地址,修改其中一个对象的属性,则另一个对象的属性也会改变,而深复制则是开辟新的栈...,两个对象对应两个不同的地址,修改一个对象的属性,不会改变另一个对象的属性。...深复制实现代码如下: 可以从两个方法进行解决。...,要想达到深复制就需要用递归 function deepCopy(o,c){ var c = c || {} for(var i in o){ if(typeof o[i...] === 'object'){ //要考虑深复制问题了 if(o[i].constructor === Array){
(value[key]); } return result; } return _deepClone(obj); } 三、ES6扩展运算符,一维对象则是深拷贝...,二维及以上则是浅拷贝。...四、JSON.stringify然后JSON.parse,如果是简单数据数据类型则可,如果value为date、null等,则会出现类型丢失情况,同时相对增加性能损耗问题(Object内的key、value...等类型都是在运行时确定的,所以stringify时需要很多工作要做)。
说到深拷贝与浅拷贝,为什么会有这两种概念呢,根本原因就在于js的两种数据类型:基本数据类型和引用数据类型,两种数据类型存储方式不同。...JavaScript 中变量的拷贝 js 中的拷贝区分为「浅拷贝」与「深拷贝」。 浅拷贝 浅拷贝只会将对象的各个属性进行依次复制,并不会进行递归复制,也就是说只会赋值目标对象的第一层属性。...深拷贝 深拷贝不同于浅拷贝,它不只拷贝目标对象的第一层属性,而是递归拷贝目标对象的所有属性。...JSON 进行忽略原型链的深拷贝 var dest = JSON.parse(JSON.stringify(target)); 同样的它也有缺点: 该方法会忽略掉值为 undefined 的属性以及函数表达式...再谈原型链属性 在项目实践中,发现有起码有以下两种方式可以来规避原型链属性上的拷贝。
现象 复制对象后,如果修改了原对象或新对象的数据,造成了对其他对象的数据也同时发生了变化的现象,就是浅拷贝;对象之间仍然存在关联。...如果复制后的对象与原对象,无论数据如何变化,都不会对其它对象带来变化,就是深拷贝;对象之间已经毫无关系。...测试类的代码片段 System.out.println("======所有类实现克隆方法的深拷贝============="); user.setAge(25); user.getName().setFirst...System.out.println("======字节数组的IO流实现深拷贝============="); //恢复原对象属性值 user.setAge(25); user.getName().setFirst...使用该工具类,对要拷贝的类没有侵入性,不需要实现任何接口,一行代码就能搞定。
); 使用JSON.parse(JSON.stringify(arr))的方式进行深拷贝时,并不会拷贝函数。...使用 JSON.parse(JSON.stringify(arr)) 进行深拷贝的方式相对简单且易于理解,适合用于处理普通的数据结构。...然而,它无法正确地处理一些特殊类型的数据,例如函数、正则表达式、日期对象等,因为这些类型在 JSON 格式中无法正确表示。 MessageChannel 使用MessageChannel实现深拷贝。...使用 MessageChannel 实现异步深拷贝,可以正确地处理任何类型的数据,包括特殊类型。 由于它是异步的方式,所以性能可能会受到一定影响,特别是在处理大型数据结构时会更明显。...浅拷贝 方式1 使用展开运算符可以轻松地复制 const arr = [1, 2, 3, 4, 5]; const clone = [...arr]; console.info(clone); 方式2
数据类型 基本类型:undefined、null、Boolean、String、Number、Symbol 引用类型:Object、Array、Date、Function、RegExp等 #存储方式 基本类型...拷贝的方式分两种: 浅拷贝 基本类型:拷贝值 引用类型:拷贝对象引用。 深拷贝 基本类型:拷贝值 引用类型:会创建一个新的引用,将之前的对象完整的拷贝一份出来,并添加至新的引用当中。...这种比较试适合简单的单个数组或者对象使用,简单又方便 #深拷贝 #JSON.stringify() 如果要拷贝的对象中包含对象,就需要深拷贝了,一般使用原生的方法JSON.parse(JSON.stringify...RegExp) return new RegExp(obj); // 可能是对象或者普通的值 如果是函数的话是不需要深拷贝 if (typeof obj !...如何写出一个惊艳面试官的深拷贝?
——《赏荷》 对象深拷贝 export function deepClone (data) { var type = getObjType(data) var obj if (type
记一下js深拷贝的几种方法 使用递归 通过JSON对象 通过jQuery的extend方法 Object.assign() lodash函数 使用递归 //使用递归的方式实现数组、对象的深拷贝 function...deepClone(obj) { //判断拷贝的要进行深拷贝的是数组还是对象,是数组的话进行数组拷贝,对象的话进行对象拷贝 var objClone = Array.isArray(obj)...的内置对象JSON来进行数组对象的深拷贝 function deepClone(obj) { var _obj = JSON.stringify(obj), objClone = JSON.parse...(_obj); return objClone; } tip: * 无法实现对对象中方法的深拷贝 通过jQuery的extend方法 var array = [1,2,3,4]; var newArray...= $.extend(true,[],array); Object.assign() 对象中只有一级属性,没有二级属性的时候,为深拷贝 对象中有对象的时候,在二级属性以后就是浅拷贝 lodash函数
/** * @param {oject} obj */ function deepClone(obj) { // obj 是 null ,或者不是对象...
然后面试中经常会问、业务中也经常会遇到的问题就是深浅拷贝的问题了。 栈内存中简单数据类型直接拷贝就能得到一个副本,但是复杂数据类型的拷贝如果也想得到一个副本,就需要深拷贝了。...深拷贝 具体深拷贝就是要理解了复杂类型拷贝的缺点,然后再进行弥补。 既然想要复杂类型也像简单类型那样拷贝一个新数据的话,就不单单是拷贝地址了。...直接返回[object String]这样类型的。但其实在深拷贝阶段,直接将其放到object形式处理了。...然后就是深拷贝的代码: deepClone: function (origin) { /* * @Author: guojufeng@ * @Date: 2018-10-30 20...如果循环过程中,数组中嵌套复杂类型,再次递归调用深拷贝方法。 对于对象,新建一个对象,然后for in遍历拷贝非原型值。如果循环过程中,对象中嵌套复杂类型,再次递归调用深拷贝方法。
1.区别: 深拷贝和浅拷贝的使用场景是在复杂对象里,即对象的属性还是对象; 浅拷贝是指只复制一层对象,当对象的属性是引用类型时,实质复制的是其引用,当引用指向的值改变时也会跟着变化;深拷贝是指复制对象的所有层级...2.深拷贝实现 Json序列化与反序列化: function deepClone(obj){ let _obj = JSON.stringify(obj), objClone =...布尔值、数字、字符串的包装对象在序列化过程中会自动转换成对应的原始值。...不可枚举的属性会被忽略 对于引用类型:object,array,date,regexp,function,err,只能深拷贝对象和数组,对于其他种类的对象,会失真。...; } else { obj[property] = obj2[property]; } } return obj; } 3.浅拷贝实现
浅拷贝 只拷贝了基本类型数据和引用类型数据的指针,叫浅拷贝 被拷贝的对象里,如果没有引用类型的数据,可以使用浅拷贝,方便快捷。...如果有引用类型,那么存在被篡改的风险,更应该使用深拷贝 浅拷贝方法 1、手撸一个浅拷贝函数 1function shallowClone(obj) { 2 const newObj = {};...、concat方法 深拷贝 完全拷贝了基本类型和引用类型内部所有数据,叫深拷贝 深拷贝方法 1、JSON暴力转换 1const obj2=JSON.parse(JSON.stringify(obj1))...; 但是这种方式存在弊端,会忽略undefined、symbol、函数、正则。...如果是函数的话是不需要深拷贝 6 if (typeof obj !
其实在工作写代码和面试中,会经常碰到这两个概念:深拷贝,浅拷贝。但今天的重点是深拷贝。 下面我将简单介绍下什么是深拷贝,浅拷贝?...深拷贝是将一个Object对象的内容完全拷贝一份给新对象。修改原对象的属性或者属性值,都不会影响新对象。原对象和新对象是完全独立的,互不影响。...3.观察obj3和obj1,可以知道利用JSON.stringify、JSON.parse实现的深拷贝,是可以实现深拷贝的。 我们再给对象加多点属性,比如加个函数。...所以通过JSON.parse和JSON.stringify实现的深拷贝不完美。 那么我分享下我自己写的一个对象深拷贝的方法,这就是我个人比较常用的方案了。...函数是能够实现深拷贝的,并且也兼容了属性值类型为function的处理,也是可以拷贝的。
1. object.assign object.assign 是 ES6 中 Object 的一个方法,该方法可以用于JS 对象的合并等多个用途,其中一个用途就是可以进行浅拷贝。...扩展运算符方式 扩展运算符的语法为:let cloneObj = { ...obj }; /* 对象的拷贝 */ const obj = { a: 1, b: { c: 1 } }...如果存在对象的嵌套,那么浅拷贝将无能为力。因此深拷贝就是为了解决这个问题而生的,它能解决多层对象嵌套问题,彻底实现拷贝。...深拷贝则不同,对于复杂引用数据类型,其在堆内存中完全开辟了一块内存地址,并将原有的对象完全复制过来存放。 深拷贝后的对象与原始对象是相互独立、不受影响的,彻底实现了内存上的分离。...实现深拷贝方法 下面是一个实现 deepClone 函数封装的例子,有几点需要注意下。
1、JS数据类型 基本数据类型:Boolean、String、Number、null、undefined 引用数据类型:Object、Array、Function、RegExp、Date等 2、深拷贝与浅拷贝...深拷贝和浅拷贝都只针对引用数据类型, 浅拷贝会对对象逐个成员依次拷贝,但只复制内存地址,而不复制对象本身,新旧对象成员还是共享同一内存;深拷贝会另外创建一个一模一样的对象,新对象跟原对象不共享内存,修改新对象不会改到原对象...区别:浅拷贝只复制对象的第一层属性,而深拷贝会对对象的属性进行递归复制。 3、赋值 当把一个对象赋值给一个新的变量时,赋的对象是该对象在栈中的地址,而不是堆中的数据。...如下: 4.浅拷贝 浅拷贝是按位拷贝对象,它会创建一个新对象,对原有对象的成员进行依次拷贝。如果属性是基本类型,拷贝的就是基本类型的值;如果属性是引用类型,拷贝的就是内存地址。...这种方法可以实现数组和对象和基本数据类型的深拷贝,但不能处理函数。
在JavaScript中,实现深拷贝(deep copy)有多种方法。以下是一些常用的方法: 1....3.使用库: lodash库的_.cloneDeep方法: import _ from 'lodash'; const newObj = _.cloneDeep(oldObj); ramda库的cloneDeep...方法: import R from 'ramda'; const newObj = R.cloneDeep(oldObj); 这些库提供了许多实用的函数,但会增加项目的依赖。...hash); } }; let cloneObj = new Proxy(obj, handler); return cloneObj; } 这种方法是最强大的,...每种方法都有其优点和局限性,应根据具体需求选择合适的方法。
浅拷贝: 思路----------把父对象的属性,全部拷贝给子对象,实现继承。...问题---------如果父对象的属性等于数组或另一个对象,那么实际上,子对象获得的只是一个内存地址,不会开辟新栈,不是真正拷贝,因此存在父对象被篡改的可能。...: function deepCopy(o){ var f = {}; for(i in o){ f[i] = o[i]; }; return f } 深拷贝...: 思路-----------递归调用'浅拷贝',可以解决子对象修改时会污染父对象,此时两个对象指向的不是一个内存地址。...[]:{}; //通过判断父级对象的属性的constructor的类型,指定子集对象属性的类型
在JavaScript中,浅拷贝和深拷贝是两种复制对象的方式,它们的主要区别在于是否复制对象的引用类型属性 浅拷贝:浅拷贝只复制对象的基本类型的属性,如果属性是引用类型(如数组、对象),则复制的是引用...这意味着如果你修改了复制后的对象的引用类型属性,原对象的对应属性也会被修改。 深拷贝:深拷贝不仅复制对象的基本类型的属性,还会复制引用类型的属性。...浅拷贝的实现 // 接收传进来的参数 可能是数组 或者是对象 function clone(obj) { // 进行obj 参数类型的判断 // 如果 object ==> {} array...newObj } 深拷贝的实现 深拷贝的主要实现步骤相较于浅拷贝 主要在于 对于原对象中引用数据类型的属性值的处理 主要使用的是函数递归的方法 一层一层的走下去 /** * 深拷贝的思路: *...对进行被拷贝对象数据类型的判断 数组 || 对象 * 2. 如果是数组 就创建一个空数组 ; 如果是对象 就创建一个空对象 (主要为了开辟新的内存空间) * 3.
领取专属 10元无门槛券
手把手带您无忧上云