有关微信小程序_JS面试题中深拷贝的完成说明

摘要: JS招聘面试题中深复制的完成解读 特性难题,stringify再分析实际上必须消耗较多時间,非常是数据信息量大的情况下。一些种类没法复制,比如涵数(不輸出),正则表达式(輸出空目...

JS面试题中深拷贝的实现讲解       在本篇文章里小编给大家分享的是关于JS面试题中深拷贝的实现讲解,需要的朋友们可以参考下。
性能问题,stringify再解析其实需要耗费较多时间,特别是数据量大的时候。 一些类型无法拷贝,例如函数(不输出),正则(输出空对象),时间对象(输出时间字符串),Undefiend(不输出) 遇到循环引用的对象会出错 同层(非同层)同引用的问题,理论下两个key对应的val如果指向同一个对象,拷贝也应该指向一个相同新地址才对

Q:那你能自己实现个深拷贝函数?

R:如下:

const deepClone = (obj) = {
 // 非引用类型及函数将直接返回
 if (!obj || typeof obj !== 'object') return obj;
 // 特殊的引用类型处理
 switch(Object.prototype.toString.call(obj).slice(8, -1)) {
 case 'Date': 
 return new Date(obj);
 break;
 case 'RegExp': 
 return new RegExp(obj);
 break;
 case 'String': 
 return new String(obj);
 break;
 case 'Number': 
 return new Number(obj);
 break;
 case 'Boolean': 
 return new Boolean(obj);
 break;
 const result = obj instanceof Array [] : {};
 for (let propName in obj) {
 if (obj.hasOwnProperty(propName)) {
 result[propName] = deepClone(obj[propName]);
 return result;
}

优点:实现了大多数数据类型的拷贝,所有非引用类型及引用类型的String Number Boolean Function Array Date RegExp

缺点:未考虑一些特殊的引用类型如Error Math Symbol Map Set JSON,函数属于引用拷贝,未解决循环引用的问题

Q:如何解决循环引用?

R:将父层级的数据缓存对比(可以顺带解决同层(非同层)同引用的问题)

const deepClone = (obj) = {
 // 非引用类型及函数将直接返回
 if (!obj || typeof obj !== 'object') return obj;
 // 特殊的引用类型处理
 switch (Object.prototype.toString.call(obj).slice(8, -1)) {
 case 'Date':
 return new Date(obj);
 break;
 case 'RegExp':
 return new RegExp(obj);
 break;
 case 'String':
 return new String(obj);
 break;
 case 'Number':
 return new Number(obj);
 break;
 case 'Boolean':
 return new Boolean(obj);
 break;
 const map = deepClone.map = deepClone.map || new Map();
 // 使用map结构可以不必循环缓存,提高效率
 if (map.get(obj)) {
 return map.get(obj);
 const result = obj instanceof Array [] : {};
 // 如果仔细观察可以发现解决了同层同引用的问题
 map.set(obj, result);
 for (let propName in obj) {
 if (obj.hasOwnProperty(propName)) {
 result[propName] = deepClone(obj[propName]);
 return result;
}

Q:为什么函数还是指向原来的函数,而不创建新函数?

R:理论下函数也可以通过new Function(code)来创建新的函数,但是如果遇到闭包函数,我们无法得到原函数的外层定义的变量及其原有作用域链,这些在JS词法解析时完成的步骤我们无法得知,所有只能引用原函数比较好。

Sum: 上面实现的缺点主要是没有完全覆盖特殊引用类型,但其实我们平时应该不会遇到那些类型,所以可以凑合使用。如果还有其它的问题没有考虑到或者有出错的,希望大家可以帮忙指出。

以上就是JS面试题中深拷贝的实现讲解的详细内容,更多关于JS深拷贝的实现的资料请关注凡科其它



联系我们

全国服务热线:4000-399-000 公司邮箱:343111187@qq.com

  工作日 9:00-18:00

关注我们

官网公众号

官网公众号

Copyright?2020 广州凡科互联网科技股份有限公司 版权所有 粤ICP备10235580号 客服热线 18720358503

技术支持:电商网站