1234567891011121314151617181920212223242526272829303132333435363738394041424344 |
- /**
- * Created by majw on 2017/4/12.
- */
- // var md5Lib = require('blueimp-md5')
- //对象深拷贝
- function deepClone(data){
- var obj = {};
- var originQueue = [data];
- var copyQueue = [obj];
- //以下两个队列用来保存复制过程中访问过的对象,以此来避免对象环的问题(对象的某个属性值是对象本身)
- var visitQueue = [];
- var copyVisitQueue = [];
- while(originQueue.length > 0){
- var _data = originQueue.shift();
- var _obj = copyQueue.shift();
- visitQueue.push(_data);
- copyVisitQueue.push(_obj);
- for(var key in _data){
- var _value = _data[key]
- if(typeof _value !== 'object'){
- _obj[key] = _value;
- } else {
- //使用indexOf可以发现数组中是否存在相同的对象(实现indexOf的难点就在于对象比较)
- var index = visitQueue.indexOf(_value);
- if(index >= 0){
- // 出现环的情况不需要再取出遍历
- _obj[key] = copyVisitQueue[index];
- } else {
- originQueue.push(_value);
- _obj[key] = {};
- copyQueue.push(_obj[key]);
- }
- }
- }
- }
- return obj;
- }
- module.exports = {
- deepClone: deepClone
- };
|