手动遍历对象拷贝

/**
* 深拷贝
* @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

最新文章

  1. Latex中插入C语言代码
  2. 多个 App 间启动
  3. Asp.Net Core 项目从 1.0.1 升级到 1.1.0 的小补丁
  4. 以软件周期C开发周期说明不同测试的使用情况
  5. iOS 单元测试之XCTest详解(一)
  6. ios 尺寸
  7. 菜鸟学JS(四)——javascript为按钮注册回车事件(设置默认按钮)
  8. C#:屏幕显示区域问题
  9. Porlet标准:JSR168/JSR286/WSRP(转载)
  10. JS面向(基于)对象编程--三大特征
  11. Windows下tuxedo配置
  12. 取消Win7任务栏窗口自动排序
  13. response 后刷新页面,点击按钮后,禁用该按钮
  14. Android之ContextMenu的使用方法以及与OptionMenu的区别
  15. 201521123082 《Java程序设计》第5周学习总结
  16. 压缩SQLServer数据库日志的一个存储过程
  17. js正则表达式入门以及常见用例
  18. HTML5的canvas标签制作黑客帝国里的简单画面
  19. SpringBoot中使用springfox+swagger2书写API文档
  20. 【python】给正则匹配部分命名

热门文章

  1. 题解【POJ2955】Brackets
  2. Flutter 中的表单
  3. maven中的pom.xml中的scope的作用
  4. 定义列属性:null,default,PK,auto_increment
  5. Unity 鼠标旋转物体360展示
  6. HGAME 2020 week1 web
  7. 7、Maven插件
  8. [C++_QT] Error: Not a signal or slot declaration
  9. 定义列表dl中标签 dt 与标签dd对齐方法,标签ul与标签li对齐
  10. python学习HTML之CSS(2)