JS实现对对象的深拷贝
2024-10-08 13:11:56
手动遍历对象拷贝
/**
* 深拷贝
* @param {*} obj 拷贝对象(object or array)
* @param {*} cache 缓存数组
*/
function deepCopy (obj, cache = []) {
// typeof [] => 'object'
// typeof {} => 'object'
if (obj === null || typeof obj !== 'object') {
return obj
}
// 如果传入的对象与缓存的相等, 则递归结束, 这样防止循环
/**
* 类似下面这种
* var a = {b:1}
* a.c = a
* 资料: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Errors/Cyclic_object_value
*/
const hit = cache.filter(c => c.original === obj)[0]
if (hit) {
return hit.copy
}
const copy = Array.isArray(obj) ? [] : {}
// 将copy首先放入cache, 因为我们需要在递归deepCopy的时候引用它
cache.push({
original: obj,
copy
})
Object.keys(obj).forEach(key => {
copy[key] = deepCopy(obj[key], cache)
})
return copy
}
使用JSON模块
根据不包含引用对象的普通数组深拷贝得到启发,不拷贝引用对象,拷贝一个字符串会新辟一个新的存储地址,这样就切断了引用对象的指针联系。
测试例子:
var test={
a:"ss",
b:"dd",
c:[
{dd:"css",ee:"cdd"},
{mm:"ff",nn:"ee"}
]
};
var test1 = JSON.parse(JSON.stringify(test));//拷贝数组,注意这行的拷贝方法
console.log(test);
console.log(test1);
test1.c[0].dd="change"; //改变test1的c属性对象的d属性
console.log(test); //不影响test
console.log(test1);
JSON.parse(),JSON.stringify()兼容性问题
可以通过为IE7以及IE7以下版本的IE浏览器引入json2.js,使用json2.js来解决JSON的兼容性问题
<!--[if lt IE 7]>
<script src="具体放路径/json2.js"></script>
<![endif]-->
json2.js的github地址为:https://github.com/douglascrockford/JSON-js
最新文章
- Latex中插入C语言代码
- 多个 App 间启动
- Asp.Net Core 项目从 1.0.1 升级到 1.1.0 的小补丁
- 以软件周期C开发周期说明不同测试的使用情况
- iOS 单元测试之XCTest详解(一)
- ios 尺寸
- 菜鸟学JS(四)——javascript为按钮注册回车事件(设置默认按钮)
- C#:屏幕显示区域问题
- Porlet标准:JSR168/JSR286/WSRP(转载)
- JS面向(基于)对象编程--三大特征
- Windows下tuxedo配置
- 取消Win7任务栏窗口自动排序
- response 后刷新页面,点击按钮后,禁用该按钮
- Android之ContextMenu的使用方法以及与OptionMenu的区别
- 201521123082 《Java程序设计》第5周学习总结
- 压缩SQLServer数据库日志的一个存储过程
- js正则表达式入门以及常见用例
- HTML5的canvas标签制作黑客帝国里的简单画面
- SpringBoot中使用springfox+swagger2书写API文档
- 【python】给正则匹配部分命名
热门文章
- 题解【POJ2955】Brackets
- Flutter 中的表单
- maven中的pom.xml中的scope的作用
- 定义列属性:null,default,PK,auto_increment
- Unity 鼠标旋转物体360展示
- HGAME 2020 week1 web
- 7、Maven插件
- [C++_QT] Error: Not a signal or slot declaration
- 定义列表dl中标签 dt 与标签dd对齐方法,标签ul与标签li对齐
- python学习HTML之CSS(2)