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

基于web的网站开发技术总结成都网站建设团队

基于web的网站开发技术总结,成都网站建设团队,企业培训视频,没有防盗链的网站🧑‍🎓 个人主页:《爱蹦跶的大A阿》 🔥当前正在更新专栏:《VUE》 、《JavaScript保姆级教程》、《krpano》 ​ ​ 目录 ✨ 前言 ✨ 正文 浅拷贝 对象的浅拷贝 数组的浅拷贝 浅拷贝的问题 深拷贝 什么是深拷贝…

🧑‍🎓 个人主页:《爱蹦跶的大A阿》

🔥当前正在更新专栏:《VUE》 、《JavaScript保姆级教程》、《krpano》

​ 

目录

✨ 前言

✨ 正文

浅拷贝

对象的浅拷贝

数组的浅拷贝

浅拷贝的问题

 深拷贝

什么是深拷贝?

如何实现深拷贝?

方法一:使用JSON对象

方法二:递归拷贝

注意事项

✨ 结语


✨ 前言

       浅拷贝和深拷贝的区别在于当对象中的属性是引用类型时,拷贝是引用的拷贝,还是引用所指向的对象的拷贝。

        浅拷贝只复制对象和其属性的引用,而不复制属性指向的对象本身。因此源对象和拷贝对象引用同一个对象。改变其中一个会影响另一个。

        深拷贝会递归复制整个对象及其属性,拷贝后的对象与原对象不共享内存,修改拷贝对象不会影响原对象。

        拷贝是编程中常见的需求,JavaScript中有深拷贝和浅拷贝之分,理解二者差异很重要。本文将全面解析拷贝的实现方式。

✨ 正文

浅拷贝

对象的浅拷贝

        浅拷贝会创建对象或数组的一份浅复制,只复制第一层的属性值,更深层次的对象仍保持引用关系。

对象的浅拷贝可以使用Object.assign():

let obj1 = {a: 1,b: {c: 2  }
};let obj2 = Object.assign({}, obj1);

        obj2只会拷贝obj1第一层的a属性值,而 deeper object b仍然指向同一个引用。

展开语法(...)也可以实现浅拷贝:

let obj2 = {...obj1};

数组的浅拷贝

        数组的slice()方法可以浅拷贝数组:

let arr1 = [1, 2, [3, 4]];
let arr2 = arr1.slice();

        arr2也只会拷贝arr1的一层元素,更深层的数组仍指向同一个。

浅拷贝的问题

        由于指向同一对象,修改会互相影响:

obj2.b.c = 20; // obj1.b.c也变为20
arr2[2].push(5); // arr1也会增加元素5

 深拷贝

什么是深拷贝?


        深拷贝是在JavaScript中复制一个对象或数组,使其成为一个完全独立的新副本。在进行深拷贝时,不仅需要复制对象本身,还需要递归地复制对象中的所有嵌套对象和数组。这确保了原始对象和拷贝对象之间的修改互不影响。

如何实现深拷贝?

方法一:使用JSON对象
let newObj = JSON.parse(JSON.stringify(oldObj));

这种方法简单易用,但是有一些局限性。例如,它不能复制函数和正则表达式对象

方法二:递归拷贝
function deepClone(obj) {let clone = Array.isArray(obj) ? [] : {};if (obj && typeof obj === "object") {for (let key in obj) {if (obj.hasOwnProperty(key)) {if (obj[key] && typeof obj[key] === "object") {clone[key] = deepClone(obj[key]);} else {clone[key] = obj[key];}}}return clone;} else {return obj;}
}

        这种方法可以复制大多数类型的对象,但是对于特殊对象,如Date对象、正则对象等,还需要特殊处理。

注意事项


        深拷贝复制所有字段,并复制字段所指向的动态分配内存。深拷贝发生在对象及其引用的对象被复制时。默认情况下基本数据类型(number,string,null,undefined,boolean)都是深拷贝

✨ 结语

        在编程的世界里,理解和掌握浅拷贝、深拷贝的概念和实现方式是非常重要的。希望通过这篇博客,你对JavaScript的浅拷贝、深拷贝有了更深入的理解。记住,不断学习和实践是提升编程技能的关键。祝你在编程的道路上越走越远,加油!

http://www.rdtb.cn/news/19303.html

相关文章:

  • 网站备案信息查询网站模板图片
  • 太原网站空间云速seo百度点击
  • 自己电脑做网站还用备案万能软文范例800字
  • wordpress cp 部署seo顾问张智伟
  • 建湖做网站价格如何提交百度收录
  • 免费企业网站源码生成黑帽seo联系方式
  • 锋云科技做网站靠谱吗淘宝推广运营
  • 网站开发去哪里找工作网站如何才能被百度收录
  • 视频直播网站开发与制作在哪里推广比较好
  • 凡科网站建设平台推广商
  • wordpress免费企业主题网站模板最权威的品牌排行榜网站
  • 长尾关键词挖掘站长工具太原百度快速优化
  • 网站宽屏搜索引擎优化的基本原理
  • 武汉百度做网站百度快照怎么删除
  • 在手机上建设网站教程链接优化方法
  • wordpress模板更改页面武汉seo优化
  • 义乌购批发网站图片扫一扫在线识别照片
  • 海关年检要去哪个网站上做百度优化公司
  • 教育网站集约化建设比较有名的个人网站
  • 智联招聘网最新招聘官网下载百中搜优化
  • wordpress 上传大文件东莞seo网络公司
  • 潜江公司做网站电商网站链接买卖
  • 烟台 网站建设多少钱aso优化分析
  • 移动网站推广人力资源培训网
  • wordpress快速登录插件百度运营优化师
  • 网站建设答辩网站建设案例
  • 装修电话seo的排名机制
  • 如何用源代码建设网站新网站应该怎么做seo
  • 做模板网站的公司拼多多网店代运营要多少费用
  • 网站seo综合诊断百度开户需要什么资质