有关数组去重与深浅拷贝!!!

数组去重
先看代码
在这里插入图片描述我们一步一步看 定义两个数组
var arr = [1,4,4,1,2,2,2,3,3,5,5,5]
//这个是带参数的
// 下一个是不带参数的用来传参:
var arr1=[]
arr.forEach(function(val,key){}
//定义数组遍历循环语句
if(arr1.indexOf(val) === -1){

             arr1.push(val)
        }

//判断 arr1数组中有没有arr数组的参数
注:在这里插入图片描述当输出索引数组中并没有时显示为-1
在这里插入图片描述所以进行判断,当arr1数组中没有arr中的数组单元时候就赋值给arr1.
if(arr1.indexOf(val) === -1){

      arr1.push(val)
    }

最后输出
在这里插入图片描述
当然这种情况是排序不是有序的,如果需要有序排列
在这里插入图片描述
第一种输出是正序输出,第二种是倒序输出。

//深浅拷贝
浅拷贝
首先我们要明白复合数据类型的储存方式,复合数据类型是在在“栈”中储存一个地址,而只要用这个地址才能去“推”中去找,一般像基本数据类型直接赋值是会覆盖调上面的值
在这里插入图片描述
在这里插入图片描述
输出str1,为上海
输出str2,为北京
如果是复合数据类型
在这里插入图片描述
找到的是地址,所以arr1赋值的地址和arr相同,所以输出结果相同
在这里插入图片描述
深拷贝
深拷贝之后在重新给arr1赋值就不会影响arr的原始值
在这里插入图片描述
输出
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在JavaScript中对数组进行去和深拷贝,可以使用以下方法: 方法一:使用浅拷贝和includes方法进行去 首先,对原数组进行深拷贝,以防止改变原数组。然后使用includes方法或indexOf方法判断数组中是否已经存在该元素,若不存在则将元素添加到新数组中。最后返回新数组作为去后的结果。 ```javascript const unique = (arr) => { const newArr = []; for (let i = 0; i < arr.length; i++) { const iValue = arr[i]; if (!newArr.includes(iValue)) { newArr.push(iValue); } } return newArr; }; const uniqueArr = unique(arr); console.log(uniqueArr); ``` 这个方法适用于普通的数组元素去,但对于包含复杂对象或嵌套数组的情况可能无法正常工作。 方法二:使用深度比较进行去 首先,对原数组进行深拷贝。然后使用findIndex方法和自定义的深度比较函数(deepEquals)判断数组中是否已经存在与当前元素相同的元素,若不存在则将当前元素添加到新数组中。最后返回新数组作为去后的结果。 ```javascript const unique = (arr) => { const newArr = []; for (let i = 0; i < arr.length; i++) { const iValue = arr[i]; if (newArr.findIndex((item) => deepEquals(item, iValue)) === -1) { newArr.push(iValue); } } return newArr; }; const uniqueArr = unique(arr); console.log(uniqueArr); ``` 这个方法可以处理包含复杂对象或嵌套数组的情况,但需要自定义一个深度比较函数(deepEquals),确保正确比较对象或数组的相等性。 请注意,以上方法仅供参考,具体实现可能因使用的编程语言版本和实际需求而有所不同。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [JS 数组方式](https://blog.csdn.net/qq_40228484/article/details/118584593)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值