JS对象浅克隆和深克隆的代码示例
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了JS对象浅克隆和深克隆的代码示例,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3245字,纯文字阅读大概需要5分钟。
内容图文
![JS对象浅克隆和深克隆的代码示例](/upload/InfoBanner/zyjiaocheng/284/77f0e20d01914e3abfd16993513c2aff.jpg)
浅克隆
先看代码:
/** * 浅克隆 克隆传入对象,只克隆一层 * @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
测试执行速度:
以上就是JS对象浅克隆和深克隆的代码示例的详细内容,更多请关注Gxl网其它相关文章!
内容总结
以上是互联网集市为您收集整理的JS对象浅克隆和深克隆的代码示例全部内容,希望文章能够帮你解决JS对象浅克隆和深克隆的代码示例所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。