js 去重 代码实现
时间: 2023-02-28 14:40:37 浏览: 2
JavaScript 去重的代码实现方法有多种,下面是其中几种常见的实现方法:
1.使用 Set:
```
var arr = [1,2,3,4,2,3];
var uniqueArr = [...new Set(arr)];
console.log(uniqueArr);
```
2.使用 Filter:
```
var arr = [1,2,3,4,2,3];
var uniqueArr = arr.filter((item, index, self) => {
return self.indexOf(item) === index;
});
console.log(uniqueArr);
```
3.使用 for 循环:
```
var arr = [1,2,3,4,2,3];
var uniqueArr = [];
for(var i = 0; i < arr.length; i++) {
if(uniqueArr.indexOf(arr[i]) === -1) {
uniqueArr.push(arr[i]);
}
}
console.log(uniqueArr);
```
相关问题
javascript数组去重代码
当我们需要对JavaScript数组进行去重时,可以使用以下几种方法:
1. 使用Set数据结构:Set是ES6中新增的数据结构,它可以存储唯一的值。我们可以将数组转换为Set,然后再将Set转换回数组即可实现去重。
```javascript
const arr = [1, 2, 2, 3, 4, 4, 5];
const uniqueArr = Array.from(new Set(arr));
console.log(uniqueArr); // [1, 2, 3, 4, 5]
```
2. 使用filter方法:利用filter方法遍历数组,返回只包含唯一值的新数组。
```javascript
const arr = [1, 2, 2, 3, 4, 4, 5];
const uniqueArr = arr.filter((value, index, self) => {
return self.indexOf(value) === index;
});
console.log(uniqueArr); // [1, 2, 3, 4, 5]
```
3. 使用reduce方法:利用reduce方法遍历数组,将不重复的值添加到新数组中。
```javascript
const arr = [1, 2, 2, 3, 4, 4, 5];
const uniqueArr = arr.reduce((prev, curr) => {
if (!prev.includes(curr)) {
prev.push(curr);
}
return prev;
}, []);
console.log(uniqueArr); // [1, 2, 3, 4, 5]
```
js 复杂数组去重代码
JavaScript中复杂数组去重的代码相对简单,可以使用filter和indexOf方法来实现。以下是一个示例代码:
```javascript
const arr = [
[1, 2],
[1, 2],
[3, 4],
[5, 6],
[5, 6],
[7, 8],
[7, 8],
[9, 10]
];
const uniqueArr = arr.filter((item, index, self) => {
return index === self.findIndex((t) => (
t[0] === item[0] && t[1] === item[1]
));
});
console.log(uniqueArr);
// 输出:[[1, 2], [3, 4], [5, 6], [7, 8], [9, 10]]
```
在上述代码中,我们使用了filter方法来过滤出不重复的项,然后使用findIndex方法来查找当前项在原数组中的第一个索引,如果当前项的索引与原数组中相同项的索引相同,则说明当前项是唯一的,否则就是重复的。
阅读全文