用JS写一个对象数组去重的函数
时间: 2023-02-26 20:27:47 浏览: 28
您可以使用以下代码来实现去重:
```
function removeDuplicates(array) {
return array.filter((item, index) => array.indexOf(item) === index);
}
```
这个函数使用 JavaScript 的 `filter` 函数,只返回数组中第一次出现的元素。 它使用 `indexOf` 函数找到每个元素第一次出现的位置,然后只保留该位置与当前元素索引相同的元素。
但是,如果数组中的元素是对象,则必须使用另一种方法,例如使用 Set 和 Map。
```
function removeDuplicates(array) {
const seen = new Map();
return array.filter(item => {
const key = JSON.stringify(item);
if (!seen.has(key)) {
seen.set(key, true);
return true;
}
return false;
});
}
```
这个函数使用了 JavaScript 的 Map 对象,以字符串形式存储对象,并使用 `has` 方法检查是否已经存在该元素。 如果不存在,它将该元素添加到 Map 并返回 true,否则返回 false。
相关问题
用js代码写一个数组去重的案例
### 回答1:
好的,以下是一个用 JavaScript 代码实现数组去重的案例:
```javascript
const arr = [1, 2, 3, 3, 4, 5, 5, 6];
const uniqueArr = [...new Set(arr)];
console.log(uniqueArr); // [1, 2, 3, 4, 5, 6]
```
这个案例中,我们使用了 ES6 中的 Set 数据结构,它可以自动去重。我们将原数组转换成 Set,然后再将 Set 转换回数组,就可以得到去重后的数组了。
### 回答2:
下面是一个用JavaScript代码实现数组去重的案例:
```javascript
function removeDuplicates(arr) {
// 使用Set数据结构对数组进行去重
// Set会自动过滤重复的元素
const uniqueArr = Array.from(new Set(arr));
return uniqueArr;
}
const arr = [1, 2, 2, 3, 4, 4, 5];
const uniqueArr = removeDuplicates(arr);
console.log(uniqueArr); // 输出结果为 [1, 2, 3, 4, 5]
```
以上代码定义了一个名为`removeDuplicates`的函数,该函数接受一个数组作为参数。在函数内部,我首先使用Set数据结构将数组转换为一个Set对象,这样会自动过滤掉数组中的重复元素。然后,我使用`Array.from`方法将Set对象转换为一个新数组,并将其返回。最后,我定义了一个测试数组`arr`,并调用`removeDuplicates`函数进行去重操作,将结果输出到控制台。
通过这个案例,我们可以了解到使用Set数据结构可以轻松地实现数组去重。Set对象只会存储唯一的值,因此当将数组转换为Set对象后,重复的元素会自动被过滤掉。
### 回答3:
要用JavaScript代码写一个数组去重的案例,可以使用两种方法进行操作:使用Set数据结构或者使用遍历比较的方式。
1. 使用Set数据结构
代码如下:
```javascript
const array = [1, 2, 3, 4, 4, 5, 6, 6];
const uniqueArray = Array.from(new Set(array));
console.log(uniqueArray); // [1, 2, 3, 4, 5, 6]
```
上述代码创建了一个包含重复元素的数组array。通过将这个数组传入Set构造函数中,可以得到一个Set对象。然后,使用Array.from方法将Set对象转换为数组,从而得到去重之后的数组uniqueArray。
2. 使用遍历比较的方式
代码如下:
```javascript
const array = [1, 2, 3, 4, 4, 5, 6, 6];
const uniqueArray = [];
for (let i = 0; i < array.length; i++) {
if (uniqueArray.indexOf(array[i]) === -1) {
uniqueArray.push(array[i]);
}
}
console.log(uniqueArray); // [1, 2, 3, 4, 5, 6]
```
上述代码使用遍历循环来逐个比较数组中的元素。通过调用indexOf方法,判断元素是否已经存在于去重后的数组uniqueArray中。如果不存在,就将该元素添加到数组中。
无论是使用Set数据结构还是使用遍历比较的方式,都可以实现数组去重的功能。不过使用Set数据结构更加简洁高效。
帮我写个js的数组去重函数
当然可以,以下是一个简单的js数组去重函数:
function unique(arr) {
return Array.from(new Set(arr));
}
这个函数使用ES6的Set数据结构来去除重复项,然后将结果转换为数组返回。
阅读全文
相关推荐










