javascript 对象克隆
2019-01-21 02:38:36来源:博客园 阅读 ()
浅克隆
先看代码:
/** * 浅克隆 克隆传入对象,只克隆一层 * @param {any} source */ function shallowClone(source) { var tiaget = createEctype(source); //创建一个副本 // 将原对象的所有属性值赋值到新对象上 for (var property in source) { if (source.hasOwnProperty(property)) { tiaget[property] = source[property]; } } /** * 创建副本 * @param {any} source */ function createEctype(source) { var newObject = {}; if (Array.isArray(source)) newObject = []; return newObject; } return tiaget; }
执行测试:
var a={a1:1,a2:2,a3:[1,2,3]}; var b={b1:1,b2:2,b3:[4,5,6]} a.b=b; b.a=a; a.a4=[a,b]; b.b4=[a,b]; a.fn=function(){console.log(this.b);}; var newa=shallowClone(a);
测试代码定义了一个自我引用的对象
a===a.a4[0]; // true a===a.b.a; // true
执行 shallowClone 方法获得了一个对象a的副本 newa
a === newa; // false newa === newa.a4[0]; // false newa === newa.b.a; // false a === newa.a4[0]; // true a === newa.b.a; // true
测试执行速度:
/** 获取传入方法在规定时间内执行次数 示例: var test = function(){ }; runTime(test,1) 表示test方法 在1秒中执行了6819005次 **/ /** * 获取传入方法在规定时间内执行次数 * @param {any} fn 执行的方法 * @param {any} time 规定的时间,单位为秒 */ function runTime(fn, time) { var startTime = Date.now(); var count = 0; while (Date.now() - startTime < time * 1000) { fn.call(); count++; } return count; }
深度克隆
代码:
/** * 深克隆 * * 示例: * var a={a1:1,a2:2,a3:[1,2,3]}; * var b={b1:1,b2:2,b3:[4,5,6]} * a.b=b; * b.a=a; * a.a4=[a,b]; * b.b4=[a,b]; * a.fn=function(){console.log(this.b);return this.b;}; * * var newa=deepClone(a); * newa.a1=123; * newa.fn(); */ function deepClone(source) { this.objKeyCache = []; // 对象缓存 this.objValueCache = []; // 对象克隆缓存 this.clone = function (source) { var target = createEctype.call(this, source); for (var property in source) { if (source.hasOwnProperty(property)) { var value = source[property]; if (typeof value === "number" || typeof value === "boolean" || typeof value === "symbol" || typeof value === "string" || typeof value === "function" || typeof value === "undefined" || value === null) target[property] = value; else if (typeof value === "object") { // 如果源对象在对象缓存中存在,就用对象克隆缓存中的值赋值 var index = this.objKeyCache.indexOf(value); if (index >= 0) target[property] = this.objValueCache[index]; else { target[property] = this.clone( value); } } else throw "未知数据类型" + (typeof value); } } return target; }; /** * 创建副本 * @param {any} source */ function createEctype(source) { var target = {}; if (Array.isArray(source)) target = []; this.objKeyCache.push(source); this.objValueCache.push(target); return target; } var newObject = this.clone(source); // 释放缓存,防止内存溢出 this.objKeyCache = []; this.objValueCache = []; return newObject; }
执行测试:
var a={a1:1,a2:2,a3:[1,2,3]}; var b={b1:1,b2:2,b3:[4,5,6]} a.b=b; b.a=a; a.a4=[a,b]; b.b4=[a,b]; a.fn=function(){console.log(this.b);return this.b;}; var newa=deepClone(a);
a === newa; // false newa === newa.a4[0] // true newa === newa.b.a; // true a === newa.a4[0]; // false a === newa.b.a; // false
测试执行速度:
原文链接:https://www.cnblogs.com/shipengfei/p/10286519.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- 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