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

免费做快闪网站网络营销主要做些什么

免费做快闪网站,网络营销主要做些什么,做能支付的网站贵吗,网站排名如何上升深拷贝我们知道是引用值的一个问题,因为在拷贝的时候,拷贝的是在内存中同一个引用。所以当其中的一个应用值发生改变的时候,其他的同一个引用值也会发生变化。那么针对于这种情况,我们需要进行深度拷贝,这样就可以做到…

深拷贝我们知道是引用值的一个问题,因为在拷贝的时候,拷贝的是在内存中同一个引用。所以当其中的一个应用值发生改变的时候,其他的同一个引用值也会发生变化。那么针对于这种情况,我们需要进行深度拷贝,这样就可以做到引用值之间互不干扰的情况。

ES5 深拷贝

function deepClone(origin, target){var target = target || {},toStr = Object.prototype.toString,arrType = '[object Array]';for (const key in origin) {if (origin.hasOwnProperty.call(origin, key)) {if(typeof origin[key] == 'object' && origin[key] !== null){target[key] = toStr.call(origin[key]) === arrType ? [] : {};deepClone(origin[key],target[key])}else{target[key] = origin[key]}}}return target;
}

ES6深拷贝

探究ES6深拷贝的之前,我们先看一下ES6中WeakMap是什么东西?在学习ES6知识中,我们知道Map是解决对象属性只能够是字符串的形式,在ES6中Map的出现,让对象的属性可以是任何类型。而WeakMapMap的主要区别在于前者是弱引用,后者是强引用。并且WeakMap的键名只能够是对象的形式。
那什么是弱引用呢?我们这里弱引用指代的是WeakMap的键名,WeakMap它的键名所引用的对象都是弱引用,即垃圾回收机制不将该引用考虑在内,因此,只要所引用的对象的其他引用都被清除,垃圾回收机制就会释放对该对象所占用的内存。也就是说,一旦不需要,WeakMap里面的键名对象和所对应的键值对就会自动的消失,不用手动删除引用。
下面的例子中,oBtn1oBtn2作为WeakMap储存的两个对象,当外界将oBtn1oBtn2删除之后,那么由于WeakMap中的键名是弱引用的原因,所以导致WeakMap里面的键名对象和所对应的键值对就会自动的消失,不用手动的删除。这也是比较合适WeakMap的使用场景。

const oBtn1 = document.querySelector('#btn1');
const oBtn2 = document.querySelector('#btn2');const oBtnMap = new WeakMap();// WeakMap
oBtnMap.set(oBtn1, handleBtn1Click);
oBtnMap.set(oBtn2, handleBtn2Click);oBtn1.addEventListener('click', oBtnMap.get(oBtn1), false);
oBtn2.addEventListener('click', oBtnMap.get(oBtn2), false);function handleBtn1Click(){}
function handleBtn2Click(){}// 删除节点
oBtn1.remove();
oBtn2.remove();

熟悉WeakMap之后,我们来看ES6深拷贝问题。其实ES6深拷贝面临的问题是引用的循环,我们先来看一个例子。从例子的现象来看,此时由于引用值的相互引用问题,导致test1test2相互引用,无限的引用下去。如果利用上面的ES5的深拷贝方式,那么就会抛出异常,所以我们尝试利用ES6的方式来更好的解决下面的这种问题。

const test1 = {};
const test2 = {};
test1.test2 = test2;
test2.test1 = test1;
console.log(test1);

image.png

function deepClone(origin, hashMap = new WeakMap()) {if (origin == null || typeof (origin) !== 'object') {return origin;}if (origin instanceof Date) {return new Date(origin);}if (origin instanceof RegExp) {return new RegExp(origin);}const hashKey = hashMap.get(origin);if (hashKey) {return hashKey;}const target = new origin.constructor();hashMap.set(origin, target);for (var key in origin) {if (origin.hasOwnProperty(key)) {target[key] = deepClone(origin[key], hashMap);}}return target;
}

image.png

http://www.wangmingla.cn/news/59593.html

相关文章:

  • 石家庄网站制作seo网站排名推广
  • 做网站界面设计注意什么网络推广包括哪些
  • 国外外贸网站有哪些今天重大新闻头条
  • 建立网站需要服务器吗网站建设开发
  • 物流网站设计毕业论文电商营销推广方法
  • 网站建设优化培训网站推广优化招聘
  • 电脑网站微信支付怎么做的seo链接优化建议
  • 做网站设计制作的公司哪里可以学seo课程
  • 兰州酒店网站建设凡科建站官网免费注册
  • 哈尔滨网站域名归那里管在线分析网站
  • 网站设计与制作教程1怎么开个人网站
  • 天津网站优化方案桔子seo网
  • 做seo网站营销推广网站搭建费用
  • 网站单页推广手机百度最新正版下载
  • 唐山网站怎么做seo武汉seo网站排名优化
  • 哈尔滨公司网站建设网络推广公司介绍
  • wordpress外网ip访问不了seo指的是
  • 南京专业网站制作公司有哪些无锡营销型网站建设
  • nba网站建设网站优化排名易下拉软件
  • 江西建设城乡网站查询北京seo优化
  • php主做哪种类型网站百度有什么办法刷排名
  • 贵阳网站备案核验点照相重庆网站搭建
  • 想攻击一个网站怎么做软文营销文章500字
  • 做维修电器网站百度地图导航
  • 武汉市网站开发公司电话廊坊网站seo
  • 柳州做网站优化太原互联网推广公司
  • wordpress更新php版本seo运营培训
  • 合肥商城网站建设哪里可以学企业管理培训
  • 惠阳市网站建设seo关键词优化案例
  • 网站做301的坏处软文网站推广法