js复杂数据类型去重

时间: 2023-10-11 14:04:37 浏览: 52
在JavaScript中,可以使用多种方法对复杂数据类型进行去重。以下是几种常用的方法: 1. 使用循环和splice方法。该方法通过两层循环对数组元素进行逐一比较,然后使用splice方法来删除重复的元素。这种方法对于NaN无法进行去重,因为NaN !== NaN。示例代码如下: ```javascript function removeDuplicate(arr) { let len = arr.length; for (let i = 0; i < len; i++) { for (let j = i + 1; j < len; j++) { if (arr[i === arr[j]) { arr.splice(j, 1); len--; // 减少循环次数提高性能 j--; // 保证j的值自加后不变 } } } return arr; } const result = removeDuplicate(arr); console.log(result); // [ 1, 2, 'abc', true, false, undefined, NaN, NaN ] ``` 2. 使用对象属性名的不可重复性。该方法利用了对象的属性名不可重复这一特性,通过遍历数组,将元素作为对象的属性名,并使用一个新数组来保存非重复的元素。示例代码如下: ```javascript function removeDuplicate(arr) { const newArr = []; const obj = {}; arr.forEach(item => { if (!obj[item]) { newArr.push(item); obj[item = true; } }); return newArr; } const result = removeDuplicate(arr); console.log(result); // [ 1, 2, 'abc', true, false, undefined, NaN ] ``` 3. 使用Set数据结构。Set是JavaScript中的一种数据结构,可以存储不重复的值。通过将复杂数据类型转换为字符串进行比较,可以实现对复杂数据类型的去重。示例代码如下: ```javascript const arr = [ { id: 1, name: 'Alice' }, { id: 2, name: 'Bob' }, { id: 1, name: 'Alice' } ]; const uniqueArr = [...new Set(arr.map(item => JSON.stringify(item)))].map(item => JSON.parse(item)); console.log(uniqueArr); // [{ id: 1, name: 'Alice' }, { id: 2, name: 'Bob' }] ``` 这些方法可以根据具体的需求选择使用,根据不同的数据类型和数据结构进行去重操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [js实现数组去重的方式(7种)](https://blog.csdn.net/qq_52732369/article/details/121877897)[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_2"}}] [.reference_item style="max-width: 50%"] - *3* [js复杂数组去重](https://blog.csdn.net/Dimples_320/article/details/129317463)[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_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

相关推荐

最新推荐

recommend-type

JS数组中对象去重操作示例

本文实例讲述了JS数组中对象去重操作。分享给大家供大家参考,具体如下: &lt;!DOCTYPE html&gt; &lt;html lang="en"&gt; &lt;head&gt; &lt;meta charset="UTF-8"&gt; &lt;title&gt;www.jb51.net js数组中对象去重&...
recommend-type

JS实现的集合去重,交集,并集,差集功能示例

主要介绍了JS实现的集合去重,交集,并集,差集功能,结合实例形式分析了javascript基于数组实现的集合去重、交集、并集、差集等相关实现技巧,需要的朋友可以参考下
recommend-type

原生JS发送异步数据请求

在做项目的时候,有时候需要用到异步数据请求,但是如果这个时候没有框架的依赖,就需要用到原生JS进行异步数据请求。这时候无非有两种请求方式,一种是AJAX,另一个是JSONP。通过原生JS对异步请求进行简单的封装。 ...
recommend-type

JS实现表格数据各种搜索功能的方法

主要介绍了JS实现表格数据各种搜索功能的方法,可实现忽略大小写,模糊搜索,多关键搜索等功能,具有一定参考借鉴价值,需要的朋友可以参考下
recommend-type

JS数组去重(4种方法)

第一种:双重循环 var ary=[1,2,3,3,2,3,4,5]; for(var i=0;i&lt;ary.length;i++){ for(var j=i+1;j&lt;ary.length;j++){ if(ary[i]===ary[j]){ ary.splice(i,1);... if(ary1.indexOf(ary[i])==-1){
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用 Python 画一个可以动的爱心

好的,我可以帮助您使用Python来绘制一个动态的爱心。您可以使用turtle库来实现。以下是实现代码: ```python import turtle import math # 设置画布和画笔 canvas = turtle.Screen() canvas.bgcolor("black") pencil = turtle.Turtle() pencil.speed(0) pencil.color("red", "pink") pencil.pensize(3) # 定义爱心函数 def draw_love(heart_size, x_offset=0, y_offset=0):
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。