js中数组对象去重的两种方法

讲解“js中数组对象去重的两种方法”的完整攻略。

1.方法1:使用Set

JavaScript中的Set是一种可以存储不重复值的集合。因此,可以通过Set来去重。

示例代码

const arr = [{id:1,name:'test'},{id:2,name:'test'},{id:1,name:'test'}]
const newArr = Array.from(new Set(arr.map(JSON.stringify))).map(JSON.parse)
console.log(newArr)

代码说明

首先使用map方法将数组中的对象转化为字符串。因为Set里默认只定义字符串,无法对对象去重。

然后使用Set方法,对其进行去重处理。

最后将Set转化为数组,再使用map方法将每项转化为对象。

2.方法2:使用reduce方法

使用reduce方法来对原数组进行去重处理,具体过程如下。

示例代码

const arr = [{id:1,name:'test'},{id:2,name:'test'},{id:1,name:'test'}]
const newArr = arr.reduce((result,current)=>{
   const len = result.length
   const isExist = result.some(item => item.id === current.id)
   if(!isExist){
     len === result.length && result.push(current)
   }
   return result
},[])
console.log(newArr)

代码说明

使用reduce方法遍历原数组,传入的第二个参数是数组初始值,这里为空数组[]。

在每次遍历时,判断result数组中是否已经存在该项,如果不存在则加入到result数组中。

最后返回去重后的新数组。

以上是两种去重方法的详细介绍。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:js中数组对象去重的两种方法 - Python技术站

(0)
上一篇 2023年5月27日
下一篇 2023年5月27日

相关文章

  • JavaScript promise的使用和原理分析

    下面是关于“JavaScript promise的使用和原理分析”的完整攻略。 简介 Promise 是 JavaScript 中一种较新的异步编程解决方案,用于解决回调函数嵌套过多的问题,使异步代码更加易于维护和阅读。Promise 对象代表了未来将要发生的事件,它是异步操作的结果的一个临时存储对象,可以让我们像同步操作一样去处理异步操作的结果。 Prom…

    JavaScript 2023年5月28日
    00
  • 微信小程序表单验证功能完整实例

    下面是关于“微信小程序表单验证功能完整实例”的详细攻略,包含了代码实现和示例说明。 1. 简介 在微信小程序开发过程中,我们经常需要使用表单来收集用户数据。为了保证数据的有效性和安全性,我们需要对表单数据进行验证。下面我们就来介绍一种微信小程序表单验证功能的完整实例。 2. 实现步骤 2.1 HTML 结构 首先,我们需要在 HTML 中添加表单元素,并设置…

    JavaScript 2023年6月10日
    00
  • JavaScript模拟实现”双11″限时秒杀效果

    下面是“JavaScript模拟实现”双11″限时秒杀效果”的完整攻略。 步骤一:准备工作 首先,在页面中添加一个倒计时的 DOM 元素。 然后,在 JavaScript 中设置秒杀开始和结束的时间,并将其转换为 Date 对象。 var startTime = new Date(‘2021-11-11 00:00:00’).getTime(); // 秒杀…

    JavaScript 2023年6月11日
    00
  • ajax技术教程基础

    关于“ajax技术教程基础”的完整攻略,下面是我整理的内容。 什么是Ajax Ajax全称 Asynchronous JavaScript And XML,翻译过来是异步的JavaScript和XML。它实际上是一种在浏览器端使用 JS 对 DOM 进行操作的技术。使用 Ajax 技术可以在不刷新整个页面的情况下更新部分网页内容,从而提高网页的用户体验。 A…

    JavaScript 2023年6月11日
    00
  • JS设置获取cookies的方法

    当我们需要在网站或应用程序中储存数据时,Cookies 是一种常见的解决方案。通过在浏览器中创建 Cookies,我们可以方便地存储用户信息、在线购物车、偏好设置等等内容。在 JavaScript 中,设置和获取 Cookies 非常简单,下面是介绍如何设置和获取 Cookies 的攻略: 设置 Cookies 使用 JavaScript 设置 Cookie…

    JavaScript 2023年6月11日
    00
  • JavaScript基础重点(必看)

    JavaScript基础重点(必看) JavaScript是一种用于网页开发的脚本语言,广泛应用于前端开发中,熟练掌握JavaScript基础是成为一名优秀的前端开发工程师的必要条件。 本篇攻略旨在讲解JavaScript的基础重点,包括基本语法、变量、数据类型、运算符、流程控制以及函数等知识点。下面是详细的讲解。 基本语法 JavaScript中的基本语法…

    JavaScript 2023年5月17日
    00
  • 解析如何利用iframe标签以及js制作时钟

    当我们需要在网页上显示时钟时,可以使用iframe标签和JS来实现。本文将详细介绍如何利用iframe标签和JS制作时钟。 步骤1:创建HTML网页 首先,在你的HTML文件中,创建一个标签,在其中指定一个id,以便在后面的JavaScript代码中引用。 <!DOCTYPE html> <html> <head> &lt…

    JavaScript 2023年6月10日
    00
  • JavaScript 笔记

    JavaScript 简介 JavsScript 于 1995 年由 Brendan Eich 用时 10 天写出,用于网景浏览器。最初的名字叫 LiveScript,也被部分员工称为 Mocha。那时 Java 语言很流行,出于商业化的考量,更名为 JavaScript,但两者之间没有关联。 最早的 JS 作为脚本语言给浏览器增加一些诸如鼠标跟随等交互性特…

    JavaScript 2023年5月7日
    00
合作推广
合作推广
分享本页
返回顶部