js 数组去重深拷贝
时间: 2023-09-10 19:12:11 浏览: 115
js数组的深拷贝
要在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 ]
阅读全文