深拷贝
function checkType(any) {return Object.prototype.toString.call(any).slice(8, -1)}function clone(any){if(checkType(any) === 'Object') { // 拷贝对象let o = {};for(let key in any) {o[key] = clone(any[key])}return o;} else if(checkType(any) === 'Array') { // 拷贝数组var arr = []for(let i = 0,leng = any.length;i<leng;i++) {arr[i] = clone(any[i])}return arr;} else if(checkType(any) === 'Function') { // 拷贝函数return new Function('return '+any.toString()).call(this)} else if(checkType(any) === 'Date') { // 拷贝日期return new Date(any.valueOf())} else if(checkType(any) === 'RegExp') { // 拷贝正则return new RegExp(any)} else if(checkType(any) === 'Map') { // 拷贝Map 集合let m = new Map()any.forEach((v,k)=>{m.set(k, clone(v))})return m} else if(checkType(any) === 'Set') { // 拷贝Set 集合let s = new Set()for(let val of any.values()) {s.add(clone(val))}return s}return any;}
深拷贝也可以使用JSON.stringify和JSON.parse来实现,但是对于属性和层级较多的对象,这样做性能会稍差一些,并且这样只能拷贝普通对象。
const person = {name: 'Sam', age: 31, child: {name: 'Ann'}};const person2 = JSON.parse(JSON.stringify(person));
浅拷贝
function shallowCopy(src) {var dst = {};for (var prop in src) {if (src.hasOwnProperty(prop)) {dst[prop] = src[prop];}}return dst;}
