千锋教育-做有情怀、有良心、有品质的职业教育机构

手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

当前位置:首页  >  千锋问问  > js去重的方法有哪些

js去重的方法有哪些

js去重 匿名提问者 2023-08-03 20:00:21

js去重的方法有哪些

我要提问

推荐答案

  在JavaScript中,数组去重有多种方法。以下是三种常用的去重方法:

千锋教育

  1. 使用Set数据结构:

  Set是一种ES6中新增的数据结构,它可以存储唯一的值,因此可以用来实现数组去重。

function removeDuplicatesWithSet(arr) {
const uniqueArray = [...new Set(arr)];
return uniqueArray;
}

const originalArray = [1, 2, 2, 3, 4, 4, 5];
const uniqueArray = removeDuplicatesWithSet(originalArray);
console.log(uniqueArray); // 输出: [1, 2, 3, 4, 5]

 

  2. 使用Array.filter()方法:

  `Array.filter()`方法可以用于过滤数组中的元素,我们可以结合`indexOf()`方法来筛选出数组中第一次出现的元素,从而实现去重。

function removeDuplicatesWithFilter(arr) {
return arr.filter((value, index, self) => self.indexOf(value) === index);
}

const originalArray = [1, 2, 2, 3, 4, 4, 5];
const uniqueArray = removeDuplicatesWithFilter(originalArray);
console.log(uniqueArray); // 输出: [1, 2, 3, 4, 5]

 

  3. 使用Object键值对:

  通过将数组元素作为对象的键名,利用对象键名的唯一性实现数组去重。

function removeDuplicatesWithObject(arr) {
const obj = {};
arr.forEach(item => obj[item] = true);
return Object.keys(obj).map(Number);
}

const originalArray = [1, 2, 2, 3, 4, 4, 5];
const uniqueArray = removeDuplicatesWithObject(originalArray);
console.log(uniqueArray); // 输出: [1, 2, 3, 4, 5]

 

  以上三种方法都可以实现数组去重,你可以根据项目需求和个人喜好选择最合适的方法。

其他答案

  •   在JavaScript中,有多种方法可以实现数组去重。以下是三种常用的去重方法:

      1. 使用Set数据结构:

      Set是一种ES6中新增的数据结构,它可以存储唯一的值,因此可以用来实现数组去重。

      function removeDuplicatesWithSet(arr) {

      const uniqueArray = Array.from(new Set(arr));

      return uniqueArray;

      }

      const originalArray = [1, 2, 2, 3, 4, 4, 5];

      const uniqueArray = removeDuplicatesWithSet(originalArray);

      console.log(uniqueArray); // 输出: [1, 2, 3, 4, 5]

      2. 使用Array.reduce()方法:

      `Array.reduce()`方法可以用来迭代数组,并将结果累积到一个值中。我们可以利用它来实现数组去重。

      function removeDuplicatesWithReduce(arr) {

      return arr.reduce((acc, current) => {

      if (!acc.includes(current)) {

      acc.push(current);

      }

      return acc;

      }, []);

      }

      const originalArray = [1, 2, 2, 3, 4, 4, 5];

      const uniqueArray = removeDuplicatesWithReduce(originalArray);

      console.log(uniqueArray); // 输出: [1, 2, 3, 4, 5]

      3. 使用for循环和indexOf()方法:

      通过遍历数组,利用`indexOf()`方法判断元素是否在新数组中已存在,从而实现数组去重。

      function removeDuplicatesWithForLoop(arr) {

      const uniqueArray = [];

      for (let i = 0; i < arr.length; i++) {

      if (uniqueArray.indexOf(arr[i]) === -1) {

      uniqueArray.push(arr[i]);

      }

      }

      return uniqueArray;

      }

      const originalArray = [1, 2, 2, 3, 4, 4, 5];

      const uniqueArray = removeDuplicatesWithForLoop(originalArray);

      console.log(uniqueArray); // 输出: [1, 2, 3, 4, 5]

      以上三种方法都能有效地实现数组去重,你可以根据具体场景和数组规模选择最适合的方法。

  •   在JavaScript中,数组去重可以通过多种方法实现。以下是三种常用的去重方法:

      1. 使用Set数据结构:

      Set是一种ES6中引入的数据结构,它可以存储唯一的值,因此可以用来实现数组去重。

      function removeDuplicatesWithSet(arr) {

      const uniqueArray = Array.from(new Set(arr));

      return uniqueArray;

      }

      const originalArray = [1, 2, 2, 3, 4, 4, 5];

      const uniqueArray = removeDuplicatesWithSet(originalArray);

      console.log(uniqueArray); // 输出: [1, 2, 3, 4, 5]

      2. 使用Array.indexOf()方法:

      通过遍历数组并利用`indexOf()`方法来判断元素是否在新数组中已存在,从而实现数组去重。

      function removeDuplicatesWithIndexOf(arr) {

      const uniqueArray = [];

      for (let i = 0; i < arr.length; i++) {

      if (uniqueArray.indexOf(arr[i]) === -1) {

      uniqueArray.push(arr[i]);

      }

      }

      return uniqueArray;

      }

      const originalArray = [1, 2, 2, 3, 4, 4, 5];

      const uniqueArray = removeDuplicatesWithIndexOf(originalArray);

      console.log(uniqueArray); // 输出: [1, 2, 3, 4, 5]

      3. 使用Array.filter()方法:

      `Array.filter()`方法可以用来过滤数组中的元素,我们可以结合`indexOf()`方法来筛选出数组中第一次出现的元素,从而实现去重。

      function removeDuplicatesWithFilter(arr) {

      return arr.filter((value, index, self) => self.indexOf(value) === index);

      }

      const originalArray = [1, 2, 2, 3, 4, 4, 5];

      const uniqueArray = removeDuplicatesWithFilter(originalArray);

      console.log(uniqueArray); // 输出: [1, 2, 3, 4, 5]

      以上三种方法都能有效地实现数组去重,你可以根据具体情况选择最适合的方法。