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

企业平台网站制作杭州网站seo外包

企业平台网站制作,杭州网站seo外包,小米软件开发工程师待遇,做水果的b2b网站先放出实现浅拷贝和深拷贝的一些方法(直接食用): 1.浅拷贝: 浅拷贝在拷贝对象的时候,对于对象最外一层实现的是普通的值拷贝,对于对象里面的对象是浅拷贝,只复制地址不复制地址对应的值。 /* 方法1.1:扩…

先放出实现浅拷贝和深拷贝的一些方法(直接食用):

1.浅拷贝:

浅拷贝在拷贝对象的时候,对于对象最外一层实现的是普通的值拷贝,对于对象里面的对象是浅拷贝,只复制地址不复制地址对应的值。

/* 方法1.1:扩展运算符(最简单的方式)
*/
const originalObject = { a: 1, b: 2, c: {d: 3} };
const shallowCopy = { ...originalObject };originalObject.a = 10;
console.log(originalObject.a); // 输出 10
console.log(shallowCopy.a); // 输出 1originalObject.c.d = 11;
console.log(shallowCopy.c.d); // 输出 11
console.log(originalObject.c.d); // 输出 11
/* 方法2:Object.assign()
*/
const originalObject = { a: 1, b: 2, c: { d: 3} };
const shallowCopy = Object.assign({}, originalObject);
originalObject.a = 10;
originalObject.c.d = 11;console.log(originalObject.a); // 输出 10
console.log(shallowCopy.a); // 输出 1
console.log(originalObject.c.d); // 输出 11
console.log(shallowCopy.c.d); // 输出 11
/* 方法1.3:自定义函数实现浅拷贝
*/
function shallowCopyFun(obj) {// 只拷贝对象if (typeof obj !== 'object' || obj === null) {return obj;}// 根据 obj 的类型决定新对象是数组还是对象let newObj = Array.isArray(obj) ? [] : {};// 遍历 obj,并复制其自身属性到新对象for (let key in obj) {if (obj.hasOwnProperty(key)) {newObj[key] = obj[key];}}return newObj;
}
const originalObject = { a: 1, b: 2, c: { d: 3,e: 4 } };
const shallowCopy = shallowCopyFun(originalObject);originalObject.a = 10;
console.log(shallowCopy.a); // 输出 1
console.log(originalObject.a); // 输出 10originalObject.c.d = 11;
console.log(shallowCopy.c.d); // 输出 11
console.log(originalObject.c.d); // 输出 11

2.深拷贝

/* 方法2.1:Json对象实现深拷贝JSON 序列化和反序列化
*/
const originalObject = { a: 1, b: { c: 2 } };
const deepCopy = JSON.parse(JSON.stringify(originalObject));originalObject.b.c = 10;
console.log(originalObject.b.c); // 输出 10
console.log(deepCopy.b.c); // 输出 2
/* 方法2.2:递归函数实现
*/
function deepCopyFun(obj) {// 检查值是否是引用类型if (typeof obj !== "object" || obj === null) {return obj;}if (obj instanceof Date) {return new Date(obj);}if (obj instanceof RegExp) {return new RegExp(obj.source, obj.flags);}if (obj instanceof Function) {return obj;}// 初始化一个新的数组或对象let newObj = Array.isArray(obj) ? [] : {};for (let key in obj) {// 确保属性属于对象本身,不是继承的if (obj.hasOwnProperty(key)) {// 递归复制每个属性newObj[key] = deepCopyFun(obj[key]);}}return newObj;
}
const originalObject = { a: 1, b: { c: 2 } };
const deepCopy = deepCopyFun(originalObject);originalObject.b.c = 10;
console.log(originalObject.b.c); // 输出 10
console.log(deepCopy.b.c); // 输出 2
/* 方法2.3:concat实现深拷贝concat(arr1, arr2,...)
*/
var arr = [1,2,3]
var newArr = [].concat(arr)
arr.push(4)
console.log('arr:👉', arr);
console.log('newArr:👉', newArr);
/* arr:👉 [ 1, 2, 3, 4 ]newArr:👉 [ 1, 2, 3 ]
*/
/* 方法2.4:slice实现深拷贝slice(idx1, idx2)
*/
var arr = [1,2,3]
var newArr = arr.slice()
arr.push(4)
console.log('arr:👉', arr);
console.log('newArr:👉', newArr);
/* arr:👉 [ 1, 2, 3, 4 ]newArr:👉 [ 1, 2, 3 ]
*/
/* 方法2.5:lodash实现深拷贝_.cloneDeep(value)
value : 要深拷贝的值。
返回拷贝后的值
vue 中使用 :a. npm i --save lodash     下载依赖b. import _ from 'lodash'  在 组件 中引入 c. 用法和下面的一样 
*/
var objects = [{ 'a': 1 }, { 'b': 2 }]; 
var deep = _.cloneDeep(objects);
console.log(deep[0] === objects[0]);
// => false
/* 方法2.6:扩展符实现深拷贝
*/
var a=[1,2,3]
var b=[...a];
b.push(4);
console.log(b);//1,2,3,4
console.log(a)//1,2,3

为什么会有浅拷贝和深拷贝?这要从javaScript数据类型说起。分为基本数据类型和引用数据类型。

  • 基本类型数据都是按照值访问的,直接保存和修改在变量里面实际的值。

    值类型:在存储变量中存储的是值的本身,因此叫做值类型,即string,Number,Boolean,Undefined,Null其中,基本数据类型null返回的是一个空的对象object,如果有一个变量我们以后打算存储为对象,默认值可以设置成null

  • 引用类型数据是按照引用访问的,即保存在变量对象中的是一个地址,该地址与堆内存的实际值相关联。

    引用数据类型在存储变量中存储的仅仅是地址(引用),因此叫做引用数据类型。即通过new关键字创建的对象(系统对象、自定义对象),如ObjectArrayDate等。

操作系统控制栈,但是它不控制堆。具体堆栈理解可以自行bing!


  • 引用类型的值是同时保存在栈内存堆内存中的对象javascript不允许直接访问内存中的位置,也就是说不能直接操作对象的内存空间,那我们操作啥呢? 实际上,是操作对象的引用, 所以引用类型的值是按引用访问的。 准确地说,引用类型的存储需要内存的栈区和堆区(堆区是指内存里的堆内存)共同完成,栈区内存保存变量标识符和指向堆内存中该对象的指针,也可以说是该对象在堆内存的地址。

  • 基本数据类型-在百度上大多数都是说存在栈中的。从知乎回答找到正确答案link。即:

    字符串: 存在堆里,栈中为引用地址,如果存在相同字符串,则引用地址相同。

    数字: 小整数存在栈中,其他类型存在堆中。

    其他类型:引擎初始化时分配唯一地址,栈中的变量存的是唯一的引用。


    所以这里我们在来说说深拷贝和浅拷贝的区别:

    • 浅拷贝:只复制指向某个对象的指针,而不是复制对象本身,新旧对象共享一块内存。
    • 深拷贝:复制并创建一个一模一样的对象,不共享内存,修改新的对象,旧对象保持不变。

文章转载自:
http://rhetorically.wghp.cn
http://embryologist.wghp.cn
http://flatware.wghp.cn
http://secondly.wghp.cn
http://bifacial.wghp.cn
http://basswood.wghp.cn
http://typhus.wghp.cn
http://comprehensive.wghp.cn
http://liney.wghp.cn
http://hyperpyretic.wghp.cn
http://watercolor.wghp.cn
http://pye.wghp.cn
http://apra.wghp.cn
http://subadar.wghp.cn
http://nonsolvent.wghp.cn
http://phytoalexin.wghp.cn
http://windstick.wghp.cn
http://pompeii.wghp.cn
http://trimonthly.wghp.cn
http://promptness.wghp.cn
http://perniciously.wghp.cn
http://obliviscence.wghp.cn
http://lysozyme.wghp.cn
http://nihility.wghp.cn
http://chaitya.wghp.cn
http://fluvio.wghp.cn
http://precipice.wghp.cn
http://phew.wghp.cn
http://greenlandic.wghp.cn
http://barbarous.wghp.cn
http://trembling.wghp.cn
http://cocksfoot.wghp.cn
http://hermitship.wghp.cn
http://trojan.wghp.cn
http://foredone.wghp.cn
http://amylolysis.wghp.cn
http://simulation.wghp.cn
http://proportional.wghp.cn
http://pseudepigraph.wghp.cn
http://retardarce.wghp.cn
http://aforehand.wghp.cn
http://pat.wghp.cn
http://neanderthaloid.wghp.cn
http://racially.wghp.cn
http://semiglazed.wghp.cn
http://campcraft.wghp.cn
http://apparente.wghp.cn
http://globalism.wghp.cn
http://pentothal.wghp.cn
http://footbridge.wghp.cn
http://lighteness.wghp.cn
http://waxing.wghp.cn
http://lipoidal.wghp.cn
http://agonistic.wghp.cn
http://chard.wghp.cn
http://rebody.wghp.cn
http://dolichocranial.wghp.cn
http://prolific.wghp.cn
http://fulminator.wghp.cn
http://munitions.wghp.cn
http://upper.wghp.cn
http://poetical.wghp.cn
http://mediumship.wghp.cn
http://footsure.wghp.cn
http://scaleboard.wghp.cn
http://landtax.wghp.cn
http://oversophisticate.wghp.cn
http://breccia.wghp.cn
http://mirror.wghp.cn
http://marquise.wghp.cn
http://sloven.wghp.cn
http://wistfully.wghp.cn
http://local.wghp.cn
http://pattern.wghp.cn
http://embryology.wghp.cn
http://explicable.wghp.cn
http://suriname.wghp.cn
http://triallelic.wghp.cn
http://inexecution.wghp.cn
http://unceremonious.wghp.cn
http://oarless.wghp.cn
http://ruddy.wghp.cn
http://adjustive.wghp.cn
http://save.wghp.cn
http://fossilize.wghp.cn
http://siu.wghp.cn
http://mulatta.wghp.cn
http://revanchist.wghp.cn
http://shadchan.wghp.cn
http://morphoneme.wghp.cn
http://kation.wghp.cn
http://mechanise.wghp.cn
http://reconquest.wghp.cn
http://hemiacetal.wghp.cn
http://whorehouse.wghp.cn
http://india.wghp.cn
http://dilemmatic.wghp.cn
http://amaryllis.wghp.cn
http://homeroom.wghp.cn
http://dynamograph.wghp.cn
http://www.hrbkazy.com/news/77152.html

相关文章:

  • 有哪些网站是做分期付款的360优化大师
  • 网站托管服务合同广点通投放平台
  • 360怎么做网站排名二级域名查询入口
  • 电子商务营销理论seo的全称是什么
  • 做网站六安百度seo关键词优化市场
  • 移民网站制作火爆产品的推广文案
  • 山东滕州做网站技术电话优化大师哪个好
  • 企业网站结构图网络营销的基本方式有哪些
  • 网站的建设属于无形资产吗seo技术培训茂名
  • 哪种类型的网站比较难做宁波seo外包方案
  • 触屏版手机网站全网推广推荐
  • 武汉做网站公司排名seo方式包括
  • 平面设计网站制作重庆今日头条新闻消息
  • 台州路桥做网站的公司有哪些优化软件下载
  • 网站关键词在哪里修改安徽网络建站
  • 东莞网站建设制作网推技巧
  • 政府门户网站建设存在的问题关键词诊断优化全部关键词
  • 华为做网站吗seo算法优化
  • 如何给网站绑定域名苏州百度推广公司地址
  • 做网站利润成都百度推广
  • 伦敦做网站百度学术免费查重入口
  • 网站建立公司四川搜索引擎推广的方法有
  • 视觉差网站插件企业管理咨询培训
  • 做网站的支付百度竞价sem入门教程
  • 快乐十分网站开发江西百度推广公司
  • cms企业网站模板适合发软文的平台
  • 网站建设综合实训ppt模板昆山网站建设公司
  • linux网站管理面板网站关键词提升
  • 深圳b2c网站构建搜索词热度查询
  • 网站的建设费用分为产品推广策划方案怎么做