js深度克隆兼顾属性循环引用
作者:互联网
function deepClone(value, mark) { if (value === null || typeof value !== 'object') { return value; // null、undefined、Boolean、String、Number、function等类型的值,直接返回 } if (value instanceof Date) { return new Date(value); // Date类型的值 } if (value instanceof RegExp) { return new RegExp(value); // 正则对象 } if (!mark) { mark = new WeakMap(); // 用于标记已经克隆过的属性,避免对象循环引用导致栈溢出 } if (mark.get(value)) { // 如果value已被克隆过了,则直接返回value return value; } let clonedValue = new value.constructor(); // 如果是数组,则构建一个[],如果是对象,则会构建一个{} mark.set(value, clonedValue); // 标记一下value已被克隆过了 for (let k in value) { clonedValue[k] = deepClone(value[k], mark); } return clonedValue; }
标签:clonedValue,return,克隆,兼顾,value,mark,new,js 来源: https://www.cnblogs.com/ourener/p/16365107.html