当前位置: 首页 > news >正文

商城网站建设公司价格网页游戏推广网站怎么做

商城网站建设公司价格,网页游戏推广网站怎么做,网页设计元素,暴利灰色偏门项目浅拷贝与深拷贝 浅拷贝是创建一个新对象#xff0c;这个对象有着原始对象属性值的拷贝。如果属性是基本类型#xff0c;拷贝的就是基本类型的值#xff0c;如果属性是引用类型#xff0c;拷贝的是内存地址 。 如果不进行深拷贝#xff0c;其中一个对象改变了对象的值这个对象有着原始对象属性值的拷贝。如果属性是基本类型拷贝的就是基本类型的值如果属性是引用类型拷贝的是内存地址 。 如果不进行深拷贝其中一个对象改变了对象的值就会影响到另一个对象的值。 深拷贝是将一个对象从内存中完整的拷贝一份出来,从堆内存中开辟一个新的区域存放新对象,且修改新对象不会影响原对象。 1、JSON.parse(JSON.stringify(obj))序列化和反序列 先将需要拷贝的对象进行JSON字符串化然后再pase解析出来赋给另一个变量实现深拷贝。 let a {a:1,b:2} let b JSON.parse(JSON.stringify(a)) a.a 11 1.1 JSON.parse(JSON.stringify(obj))深浅拷贝的缺陷 let a {name: Jack,age: 18,hobbit: [sing, {type: sports, value: run}],score: {math: A,},run: function() {},walk: undefined,fly: NaN,cy: null,date: new Date() } let b JSON.parse(JSON.stringify(a))取不到值为 undefined 的 key如果对象里有函数函数无法被拷贝下来无法拷贝copyObj对象原型链上的属性和方法对象转变为 date 字符串。 2. Object.assign(target, source1, source2) es6新增的方法可用于对象合并将源对象的所有可枚举属性复制到目标对象上。 var data {a: 123,b: 123,c: true,d: [43, 2],e: undefined,f: null,g: function() { console.log(g); },h: new Set([3, 2, null]),i: Symbol(fsd),k: new Map([ [name, 张三], [title, Author] ])};var newData Object.assign({},data) console.log(newData) 可以看到这个API可以将源对象上的全部数据类型属性值完全复制到一个新的对象上这难道就是我们所寻找的最完美的深拷贝方式了吗答案是否只能说是部分深拷贝或者说就是浅拷贝为什么这么说呢接着往下看。 var test { name: 张三 } var data { a: 123,b: test} var newData Object.assign({},data) console.log(newData) // { a: 123, b: { name: 张三 }} test.age 18 console.log(newData) // { a: 123, b: { name: 张三, age: 18 }}结果很明显这种方式的拷贝如果源目标对象中某个属性值是对另一个对象的引用那么这个属性的拷贝仍然是对引用的拷贝。  3、普通递归函数实现深拷贝  function deepClone(source) {if (typeof source ! object || source null) {return source;}const target Array.isArray(source) ? [] : {};for (const key in source) {if (Object.prototype.hasOwnProperty.call(source, key)) {if (typeof source[key] object source[key] ! null) {target[key] deepClone(source[key]);} else {target[key] source[key];}}}return target; } 3.1、解决循环引用和symblo类型 function cloneDeep(source, hash new WeakMap()) {if (typeof source ! object || source null) {return source;}if (hash.has(source)) {return hash.get(source);}const target Array.isArray(source) ? [] : {};Reflect.ownKeys(source).forEach(key {const val source[key];if (typeof val object val ! null) {target[key] cloneDeep(val, hash);} else {target[key] val;}})return target; } 4. 迭代递归方法解决闭环问题 function deepCopy(data, hash new WeakMap()) {if(typeof data ! object || data null){throw new TypeError(传入参数不是对象)}// 判断传入的待拷贝对象的引用是否存在于hash中if(hash.has(data)) {return hash.get(data)}let newData {};const dataKeys Object.keys(data);dataKeys.forEach(value {const currentDataValue data[value];// 基本数据类型的值和函数直接赋值拷贝 if (typeof currentDataValue ! object || currentDataValue null) {newData[value] currentDataValue;} else if (Array.isArray(currentDataValue)) {// 实现数组的深拷贝newData[value] [...currentDataValue];} else if (currentDataValue instanceof Set) {// 实现set数据的深拷贝newData[value] new Set([...currentDataValue]);} else if (currentDataValue instanceof Map) {// 实现map数据的深拷贝newData[value] new Map([...currentDataValue]);} else { // 将这个待拷贝对象的引用存于hash中hash.set(data,data)// 普通对象则递归赋值newData[value] deepCopy(currentDataValue, hash);} }); return newData;}比之前的1.0版本多了个存储对象的容器WeakMap思路就是初次调用deepCopy时参数会创建一个WeakMap结构的对象这种数据结构的特点之一是存储键值对中的健必须是对象类型。 首次调用时weakMap为空不会走上面那个if(hash.has())语句如果待拷贝对象中有属性也为对象时则将该待拷贝对象存入weakMap中此时的健值和健名都是对该待拷贝对象的引用然后递归调用该函数再次进入该函数传入了上一个待拷贝对象的对象属性的引用和存储了上一个待拷贝对象引用的weakMap因为如果是循环引用产生的闭环那么这两个引用是指向相同的对象的因此会进入if(hash.has())语句内然后return退出函数所以不会一直递归进栈以此防止栈溢出。 总结 上述的几种方式不管优缺点如何共同点是只能拷贝对象的可枚举属性对于不可枚举或者原型上的属性却不能拷贝但对于基本的使用来说已经足够了。
http://www.tj-hxxt.cn/news/216333.html

相关文章:

  • 社交网站图片展示深圳龙华网站建设
  • 网站建设要不要监理金融app开发
  • 深圳哪家网站建设公司好自己制作logo免费 生成器
  • 网站命名的原则包括北京建设工程交易中心招标网
  • 奉贤高端网站建设网站导航html源码
  • 餐厅网站建设什么经典网页传奇
  • 深圳网站制作公司信息观光园网站建设
  • 长沙给中小企业做网站的公司用织梦做网站费用
  • 建设信用卡申请官方网站网站开发制作
  • 网站开发实训心得800字广东 网站经营性备案
  • 济南外贸网站建设公司排名常州装修网站建设公司
  • 网站搭建h5是什么网络装修平台哪家最好
  • 做国际网站有用网站锚文本的内链建设
  • 安庆网站建设公司简网站推广营销技巧
  • 学校网站建设市场分析最好的网站建设组织
  • 网站常用的优化方法泰安信息平台体温
  • 北京网站开发飞沐网站改版注意事项
  • 网站运营推广该如何做县级网站建设培训会
  • 百度云建站网站建设长治做网站
  • 知乎有趣的网站分析网站建设前期的seo准备工作
  • 县级门户网站建设的报告网站建设销售总结
  • 店铺推广和网站优化一起做东营网站建设seo
  • vs做网站图片明明在文件夹里却找不到wordpress 主题教程 水煮鱼
  • 做k12网站效果图设计费收费标准
  • asp网站建设实验设计企业信息平台网站官网
  • asp网站手机模版金普新区城乡建设局网站
  • 中国建设银行陕西分行官方网站嵌入式软件开发培训班
  • 长春新建火车站企业网站建设的必要性和重要性
  • 网站备案还是域名备案网站版面的图文是怎么做的
  • wordpress和站点中国生态文明建设的意义和目标