javascript中json或数组深拷贝解决方法及实例

栏目: JavaScript · 发布时间: 5年前

let arr = { a:1, b:2 }
 let arr2 = { ...arr }
 arr.a = 1111
 console.log(arr,arr2)
复制代码

2. Ojbect.assign(目标对象,源对象)--ES6

let arr = { a:1, b:2 }
let arr2 = Object.assign({},arr)
arr.a = 1111
console.log(arr,arr2)
复制代码

深拷贝多级(json,数组)包含只有一级

1.简单直接点的 JSON.parse(JSON.stringify(对象))

let arr = { a: { age: 12 }, b:2 }
let arr2 = JSON.parse(JSON.stringify(arr))
arr.a.age = 18
console.log(arr,arr2)
复制代码

2.自定义一个函数实现深度拷贝

function copy(obj){
	/**
		只需要三步就ok
		第一步: 使用typeof判断obj是否是一个对象
		第二步: 初始化一个新的对象(使用obj.constructor判断是数组还是json)
		第三步: 遍历对象 将每一个元素是基本数据类型的赋值给新的对象,否则递归此方法
	*/

	if(typeof obj !== 'object'){
		return
	}
	let newobj = obj.constructor === Array ? [] : {}
	for(let i in obj){
		newobj[i] = typeof obj[i] === 'object' ? copy(obj[i]) : obj[i]
	}
	return newobj
}
let arr = { a: { age: 12 }, b:2 }
let arr2 = copy(arr)
arr.a.age = 18
console.log(arr,arr2)
复制代码

3. 使用eval()函数

let arr = { a: { age: 12 }, b:2 }
let arr2 = eval("("+JSON.stringify(arr)+")")
arr.a.age = 18
console.log(arr,arr2)
复制代码

以上所述就是小编给大家介绍的《javascript中json或数组深拷贝解决方法及实例》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

深度学习轻松学

深度学习轻松学

冯超 / 电子工业出版社 / 2017-7 / 79.00

《深度学习轻松学:核心算法与视觉实践》介绍了深度学习基本算法和视觉领域的应用实例。书中以轻松直白的语言,生动详细地介绍了深层模型相关的基础知识,并深入剖析了算法的原理与本质。同时,书中还配有大量案例与源码,帮助读者切实体会深度学习的核心思想和精妙之处。除此之外,书中还介绍了深度学习在视觉领域的应用,从原理层面揭示其思路思想,帮助读者在此领域中夯实技术基础。 《深度学习轻松学:核心算法与视觉实......一起来看看 《深度学习轻松学》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器