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

开原网站网站建设中国设计网字体

开原网站网站建设,中国设计网字体,婚庆企业网站建设,自己怎么开网站本文不会具体介绍扩展运算符的基本用法。 只是分享在项目中踩坑的点。 你以为的扩展运算符只是复制的功能#xff0c;其实会偷偷修改你的原数组 案例#xff1a; 假如arr [...arr2] #xff0c;修改arr的值会改变arr2的值吗? 解决方案#xff1a; case1 使用 arr […本文不会具体介绍扩展运算符的基本用法。 只是分享在项目中踩坑的点。 你以为的扩展运算符只是复制的功能其实会偷偷修改你的原数组 案例 假如arr [...arr2] 修改arr的值会改变arr2的值吗? 解决方案 case1 使用 arr [...arr2] 语法创建一个新的数组 arr并将 arr2 中的元素复制到 arr 中。这意味着 arr 和 arr2 是不同的数组实例它们的引用不同。因此修改 arr 不会直接影响到 arr2。 例如 int[] arr2 {1, 2, 3}; int[] arr [...arr2];arr[0] 10;System.out.println(Arrays.toString(arr)); // 输出[10, 2, 3] System.out.println(Arrays.toString(arr2)); // 输出[1, 2, 3]在上述示例中将 arr2 的值复制到 arr 中后修改 arr 的第一个元素并不会影响到 arr2。 case2 但需要注意的是如果数组 arr2 中的元素是对象的引用而不是基本类型如整数那么 arr 和 arr2 中的元素引用将指向相同的对象。在这种情况下修改对象本身可能会影响到两个数组。 例如 class Person {String name;public Person(String name) {this.name name;} }Person[] arr2 {new Person(Alice), new Person(Bob)}; Person[] arr [...arr2];arr[0].name Charlie;System.out.println(arr[0].name); // 输出Charlie System.out.println(arr2[0].name); // 输出Charlie在这个示例中修改 arr 中的第一个元素的名称属性同时也会影响到 arr2 中的第一个元素因为它们引用的是同一个 Person 对象。 总结起来对于基本类型数组使用 arr [...arr2] 创建的新数组与原始数组是独立的。但对于引用类型数组修改对象本身可能会影响到两个数组。 如果我想要创建一个与arr2相同的数组并且修改它不会影响到arr2应该怎么做 要创建一个与 arr2 相同的数组并确保修改它不会影响到 arr2你可以使用数组的拷贝方法来实现。以下是一些常见的方法 可以使用 slice() 方法或扩展运算符 ([...arr2]) 创建一个新的数组副本。 const arr2 [1, 2, 3]; const arr arr2.slice(); // 或者 const arr [...arr2];arr[0] 10;console.log(arr); // 输出[10, 2, 3] console.log(arr2); // 输出[1, 2, 3]请注意这些方法是针对普通的数组如整数数组的如果你使用的是引用类型数组如对象数组需要确保对象也被复制而不仅仅是引用。在这种情况下你可能需要使用深拷贝方法以确保对象的属性也被复制。 综上所述通过使用适当的数组拷贝方法你可以创建一个与 arr2 相同的数组并确保对它的修改不会影响到 arr2。 拷贝一个对象数组并且新数组改变后不要影响旧数组 如果你想要拷贝一个对象数组并确保新数组的修改不会影响到旧数组你需要进行深拷贝deep copy。深拷贝会创建一个新的数组并逐个复制对象及其属性而不仅仅是复制对象的引用。具体方法如下 JavaScript你可以使用 JSON.parse(JSON.stringify(arr2)) 进行深拷贝。 const arr2 [{ name: Alice }, { name: Bob }]; const arr JSON.parse(JSON.stringify(arr2));arr[0].name Charlie;console.log(arr); // 输出[{ name: Charlie }, { name: Bob }] console.log(arr2); // 输出[{ name: Alice }, { name: Bob }]你可以通过遍历原数组并逐个复制对象来创建一个新的数组。 注意深拷贝方法适用于对象数组其中对象包含属性。如果对象中还包含其他嵌套对象或集合等你需要相应地对嵌套对象进行深拷贝。 const arr2 [{ name: Alice }, { name: Bob }];// 方法2: 使用递归进行深拷贝 function deepCopy(obj) {if (typeof obj ! object || obj null) {return obj;}let copy Array.isArray(obj) ? [] : {};for (let key in obj) {if (obj.hasOwnProperty(key)) {copy[key] deepCopy(obj[key]);}}return copy; }const arr deepCopy(arr2);arr[0].name Charlie;console.log(arr); // 输出[{ name: Charlie }, { name: Bob }] console.log(arr2); // 输出[{ name: Alice }, { name: Bob }]在上述示例中我们使用了两种方法来实现深拷贝。第一种方法使用 JSON.stringify 将对象数组转换为字符串然后使用 JSON.parse 将字符串转换回对象数组从而实现深拷贝。第二种方法是使用递归函数 deepCopy 对对象进行逐个属性的深拷贝。 不论你选择哪种方法都可以创建一个与 arr2 相同的对象数组并确保对新数组的修改不会影响到旧数组 arr2。
http://www.hkea.cn/news/14463492/

相关文章:

  • 网站建设分金手指专业二九哪个网站可以学做包子
  • 下载了wordpress后汕头seo网站优化
  • 淘宝客网站的建设杭州高瑞网站建设
  • 头条网站怎么做建设信用卡官网网站
  • 网站设计工作流程深圳企业网站建设服务好
  • 积极推进政务网站建设蓝田网站建设
  • 四川绵阳网站建设山东省工程建设信息网
  • 企业网站建设费用 珠海濮阳网站优化
  • 免费vip影视网站怎么做的wordpress顶部修改
  • 网站建设毕业设计总结纯 flash 网站
  • 哪个网站有适合小学生做的题wordpress登陆接口
  • 网站开发都是用什么框架做网站用html还是python好
  • 天津网站建设 熊掌号网站建设整个过程
  • 现在个人做网站还能盈利深圳网站建设电话咨询
  • 东莞建网站公司哪个好购物网站建设 属于信息系统管理与设计么
  • 外贸网站如何做的好没有网怎么装wordpress
  • 网站建设app手机下载格力空调显示h5是什么意思
  • 学校网站管理系统免费版平面设计类的网站
  • dw做企业网站wp 企业网站模板
  • 自媒体图片素材网站罗湖网站建设-信科网络
  • 自适应网站开发seo手机网站 制作
  • 外贸企业网站制作公司深圳市西特塔网站建设工作室
  • 无锡网站营销公司简介wordpress文件权限设置
  • 网站建设模板网站wordpress添加留言
  • 网站目录结构 权限私人订制软件平台
  • 六年级做网站的软件软件技术主修课程
  • 广州手机网站建设哪家好东莞市手机网站建设
  • 乌海学校网站建设wordpress 迁站
  • 苏州网站开发找薇seo如何快速出排名
  • 医院网站建设 利法拉网络深圳品牌设计公司的发展