vue对数据的深复制
judgeType(obj) {
const toString = Object.prototype.toString;
const map = {
'[object Boolean]': 'boolean',
'[object Number]': 'number',
'[object String]': 'string',
'[object Function]': 'function',
'[object Array]': 'array',
'[object Date]': 'date',
'[object RegExp]': 'regExp',
'[object Undefined]': 'undefined',
'[object Null]': 'null',
'[object Object]': 'object',
};
if (obj instanceof Element) {
return 'element';
}
return map[toString.call(obj)];
},
deepClone(data) {
const type = this.judgeType(data);
let obj;
if (type === 'array'){
obj = [];
} else if (type === 'object') {
obj = {};
} else {
return data;
}
if (type === 'array'){
for (let i = 0, len = data.length; i < len; i++) {
obj.push(this.deepClone(data[i]));
}
} else if (type === 'object') {
for (const key in data) {
obj[key] = this.deepClone(data[key]);
}
}
return obj;
},
复制代码
转载于:https://juejin.im/post/5afea5226fb9a07aa11472e8