JavaScript对象复制
2018-06-24 01:13:13来源:未知 阅读 ()
近期项目因为怕数据污染所以用到了js的对象复制
js里的对象都是继承自object,是引用类型,所以无法通过=号复制
所以整理了一些常用的复制方法,如下
一、通过JSON序列化和反序列化创建新的对象
1 var obj = { a: 1, b: '2' }; 2 var newObj = JSON.parse(JSON.stringify(obj));
测试一下:
obj.a = 3;//obj和newObj指向了不同的引用,所以newObj的b属性并不会变化 console.log(newObj);
console.log(obj);
测试结果:
然而,这个方法并不能进行深度复制,对于function属性并不能复制到。那么就有了下面的深度复制方式
二、深度对象复制
function clone(o) { var s = {}; for (var k in o) s[k] = typeof o[k] === 'object' ? clone(o[k]) : o[k]; return s; }
测试一波:
var obj = { a: 1, b: 'b', c: false, d: new Date(), e: { e: 1 }, f: function () { console.log(this.g) }, g: [1, 2] }; var newObj = clone(obj); console.log(newObj);
newObj.f();
测试结果:
二、Array的快速复制
Array.prototype.concat可以拼接两个数组并返回新对象,利用这一特性,可以快速复制一个数组
var arr1 = [1]; var arr2 = [].concat(arr1);
测试一波:
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:ajaxJson(常用)
- javascript面向对象入门基础详细介绍 2020-03-29
- JavaScript函数表达式详解及实例 2020-03-25
- 如何用javascript连接access数据库 2020-03-20
- js中去掉字串左右空格 2020-03-20
- Javascript中的经典技巧 2020-03-20
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash