JavaScript对象的浅拷贝与深拷贝实例分析
本文实例讲述了JavaScript对象的浅拷贝和深拷贝。分享给大家供大家参考,具体如下
1、浅拷贝
仅仅复制对象的引用,而不是对象本身。
var person = { name: 'Alice', friends: ['Bruce', 'Cindy'] } var student = { id: 30 } student = simpleClone(person, student); student.friends.push('David'); alert(person.friends); function simpleClone(oldObj, newObj) { var newObj = newObj || {}; for (var i in oldObj) newObj[i] = oldObj[i]; return newObj; }
使用在线HTML/CSS/JavaScript代码运行工具,测试运行结果
给子对象的数组类型的属性添加一个新值,父对象的该属性值也被篡改。
2、深拷贝
把复制的对象所引用的全部对象都复制一遍,能够实现真正意义上的数组和对象的拷贝。
浅拷贝的问题如果父对象的属性值为一个数组或另一个对象,那么实际上子对象获得的只是一个内存地址,而不是对父对象的真正拷贝,存在父对象被篡改的可能。
解决方法使用深拷贝。
var person = { name: 'Alice', friends: ['Bruce', 'Cindy'] } var student = { id: 30 } student = deepClone(person, student); student.friends.push('David'); alert(person.friends); // 'Bruce', 'Cindy' function deepClone(oldObj, newObj) { var newObj = newObj || {}; newObj = JSON.parse(JSON.stringify(oldObj)); return newObj; }
使用在线HTML/CSS/JavaScript代码运行工具,测试运行结果
3、实现深拷贝的方法
1) 方法1使用JSON.parse()方法
function deepClone(oldObj, newObj) { var newObj = newObj || {}; newObj = JSON.parse(JSON.stringify(oldObj)); return newObj; }
优点
简单易用。
缺点
① 会抛弃对象的constructor,即,深拷贝后,不管该对象原来的构造函数是什么,在深拷贝之后都会变成Object。
② 能正确处理的对象只有 Number, String, Boolean, Array,即那些能够被JSON直接表示的数据结构,RegExp对象等无法通过这种方式深拷贝。
2) 方法2递归拷贝
function deepClone(oldObj, newObj) { var newObj = newObj || {}; for (var i in oldObj) { if (typeof oldObj[i] === 'object') { newObj[i] = (oldObj[i].constructor === Array) ? [] : {}; arguments.callee(oldObj[i], newObj[i]); } else newObj[i] = oldObj[i]; } return newObj; }
问题当遇到两个互相引用的对象,会出现死循环的情况。
解决方法在遍历时判断两个对象是否相互引用(如oldObj.property === newObj),如果是则退出循环。
function deepClone(oldObj, newObj) { var newObj = newObj || {}; for (var i in oldObj) { var prop = oldObj[i]; if (prop === newObj) continue; if (typeof prop === 'object') { newObj[i] = (prop.constructor === Array) ? [] : {}; arguments.callee(prop, newObj[i]); } else newObj[i] = prop; } return newObj; }
3) 方法3使用Object.create()
方法
function deepClone(oldObj, newObj) { var newObj = newObj || {}; for (var i in oldObj) { var prop = oldObj[i]; if (prop === newObj) continue; if (typeof prop === 'object') newObj[i] = (prop.constructor === Array) ? [] : Object.create(prop); else newObj[i] = prop; } return newObj; }
4)方法4使用jQuery.extend()
和jQuery.fn.extend()
请见
更多关于JavaScript相关内容感兴趣的读者可查看本站专题《》、《》、《》、《》及《》
希望本文所述对大家JavaScript程序设计有所帮助。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程