vue 对数据的克隆
调函数deepClone()即可此数据克隆不影响原始数据开辟栈空间例如对 data中tableData复制 即deepClone(this.tableData)judgeType(obj) {// tostring会返回对应不同的标签的构造函数const toString = Object.prototype.toString;const map = {...
·
调函数deepClone()即可 此数据克隆不影响原始数据开辟栈空间
例如对 data中tableData复制 即 deepClone(this.tableData)
judgeType(obj) {
// tostring会返回对应不同的标签的构造函数
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;
},
更多推荐
已为社区贡献6条内容
所有评论(0)