js数组或对象除去重复元素的四种方法

2023-10-27

1.利用对象的属性名来存储不重复的元素或者说利用对象的属性名来筛选重复的元素

        let arr = [0,2,2,3,4,5,3,3,5,4,'l','a','p','l','p','a'];
        let obj = {};
        let arrs = [];
        let arrLength = arr.length;
        for(let i = 0; i < arrLength; i++){
            if(!obj[arr[i]]){//如果obj的属性名(arr[i]作为obj的属性名)不存在,即这是第一次遇见的元素(一个不重复的元素)
                obj[arr[i]] = ‘lap’;//这个‘lap’可以随便设置成一个非空值,
                arrs.push(arr[i]);//将这个元素加入到数组arrs中
            }
        }
        console.log('arrs:',arrs);

         因为obj这个对象的属性名存储了不重复元素,可以直接输出keys(obj)。但是如果你是在编辑器里面用console.log('keys(obj):',keys(obj));chrome会报错:keys is not defined.我的chrome版本是69,可能有点小bug,直接在chorme控制台输出console.log(keys(obj))是没有问题的。

        

2.利用数组的indexOf(),与第一种方法相比我觉得很相似,

indexOf() 方法可返回数组中某个指定的元素位置。

该方法将从头到尾地检索数组,看它是否含有对应的元素,如果有,则返回 元素第一次出现的位置,否则返回-1。开始检索的位置在数组的开头,也可以加参数改变起始的检索位置

let arr = [0,2,2,3,4,5,3,3,5,4,'l','a','p','l','p','a','x','x'];
        let arrs = [];
        let arrLength = arr.length;
        for(let i = 0; i < arrLength; i++){
            if(arrs.indexOf(arr[i]) < 0){//第一次检索到的元素是 -1,重复的元素是大于0的
                arrs.push(arr[i]);//将这个元素加入到数组arrs中
            }
        }
        console.log('arrs:',arrs);

       这个方法的好处应该就是不需要像第一种方法定义一个空对象,这里使用了数组自带的indexOf(),

3.利用filter()函数

let arr = [0,2,2,3,4,5,3,3,5,4,'l','a','p','l','p','a','y','y'];
    let arrs = arr.filter(function(ele,index,self){
        return self.indexOf(ele) === index;
    });

    console.log(arrs);

4.利用ES6的Set数据结构,Set类似数组,但里面的元素不重复

     let arr = [0,2,2,3,4,5,3,3,5,4,'l','a','p','l','p','a','z','z'];
    let arrs = [...new Set(arr)];
    console.log(arrs,arrs instanceof Array);

 

上面四种方法 ,个人觉得第四种方法最简洁方便。

 

 

 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

js数组或对象除去重复元素的四种方法 的相关文章

  • 记录自己在结构光三维重建领域的学习过程(一)

    仿真数据集与真是数据集之间差异较大 二者的网络均不可完美预测另一种数据 寻找解决办法 首先确定是不是数据的问题 阅读论文 Light field structured light projection data generation wit
  • 关于存储过程中SQL语句IN条件传参注意说

    背景说明 在数据库操作中我们经常会用到查询语句 在一些情况下 需要使用到IN条件 正常的查询中IN需要注意的是最好in中的参数不能超过1000个 超过1000的时候oracle会抛出异常 这个如何处理先不提 这次要说的是 如果在存储过程中使
  • 某单位分配到一个地址块 136.23.12.64/26。现在需要进一步划分为4个一样大的子网。试问:

    1 每个子网的网络前缀有多长 2 每个子网中有多少个地址 3 每个子网的地址块是什么 4 每一个子网可分配给主机使用的最小地址和最大地址是什么 姐
  • JS中的邮箱验证

    通过js在前端对用户输入进行校验 即可以产生较好的交互体验 也可以减轻后台的压力 邮箱的基本格式要求 1 只能以单词字符开头 即a z A Z 0 9 2 只能有一个 3 后面有一个到多个点 并且点不能在最后 4 特殊字符不能开头和结尾 使
  • 数据存储,详细讲解

    数据存储 详细讲解 数据类型的介绍 整形的内存存储 大小端介绍 浮点数的存储 数据类型的介绍 1 内置类型 char 字符数据类型 1 short 短整型 2 int 整形 4 long 长整型 4 8 long long 更长的整形 8
  • matlab之数组反序输出

    a 1 2 3 4 5 a end 1 1 5 4 3 2 1 转载于 https www cnblogs com yibeimingyue p 11201805 html
  • 高阶数据结构之并查集

    文章目录 并查集 并查集的常规实现 并查集的简化实现 算法题 模板 朴素的并查集 维护size的并查集 维护到祖宗节点的并查集 并查集 在某些应用问题中 需要将n个不同的元素划分成一些不想交的集合 开始时 每个元素自成一个单元集合 然后按照
  • 一文搞懂状态模式

    原理 状态机有三个组成部分 状态 事件 动作 遇到不同的事件会触发状态的转移和动作的执行 不过动作不是必须的 可能只有状态的转移 没有动作的执行 状态模式的目的就是实现状态机 案例带入 比如 超级马里奥 在游戏中 马里奥可以变身为多种形态
  • 抖音究竟对线下生意有没有价值?

    戳上方增长黑盒Growthbox点亮星标 深度研究不错过 主笔 邹小困 研究员 彬超 Emma 出品 增长黑盒研究组 01 防火防盗防抖音 互联网世界的后起之秀字节跳动 如同进击的巨人 在短短几年内就已将业务的触角伸向各个领域 图为chat
  • Java基础(IO输入输出流,读写文件操作,对象序列化)

    IO 输入输出流基本概念 输入流 信息从程序空间之外的地方流入程序空间里面 输出流 信息从程序空间里面流到程序空间之外的地方 输入输出流的分类 从流的方法划分 输入流 输入流 从流的分工划分 节点流 访问文件进行输入输出操作的流 处理流 在
  • IDEA常见错误:程序包org.apache.commons.xxx不存在

    具体错误 Could not transfer artifact org apache commons commons text pom 1 1 from to Nexus Repository Nexus Repository Manag
  • 全新【Photoshop 2022 for mac】中文版发布下载 支持M1 M1X M2处理器 详细安装教程

    Adobe PhotoShop 2022 for mac 23 0 是 Adobe 2022 中最重要的组成软件之一 PhotoShop主要用来处理图像 是行业内最流行的图像处理软件 ps 2022 更加智能化和强大 Adobe Photo
  • CAN db++(创建DBC文件)学习笔记

    CAN db 学习笔记 1 新建文件 2 模块介绍 3 建立DBC的过程 自下而上 信号 报文 节点 1 信号 2 报文 3 建立报文与信号的关系 4 建立信号在报文里的位置 因为前面定义了报文的数据长度 且把信号放到了报文里面 那么信号在
  • 【Linux_CentOS7】 systemctl restart named报错-Job for named.service failed because the control process

    14天阅读挑战赛 努力是为了不平庸 算法学习有些时候是枯燥的 这一次 让我们先人一步 趣学算法 欢迎记录下你的那些努力时刻 算法学习知识点 算法题解 遇到的算法bug 等等 在分享的同时加深对于算法的理解 同时吸收他人的奇思妙想 一起见证技
  • Taro+vue3小程序开启分享他人和分享到朋友圈

    import Taro useShareAppMessage useShareTimeline from tarojs taro onMounted gt Taro showShareMenu withShareTicket true me
  • 有趣的java代码_求一些有趣的java小程序?

    不请自来 用eclipse写的一个输出爱心的小程序 应该算是比较有趣的吧 下面是程序内容 public class love public static void main String args TODO Auto generated m
  • BeanUtils.copyProperties的用法(超详细,建议收藏)

    常见场景 我们如果有两个具有很多相同属性名的JavaBean对象a和b 想把a中的属性赋值到b 例如 接口中将接收到的前端请求参数XxxReqVo 我们想把这个入参转化为XxxQuery对象作为数据库的查询条件对象 传统做法是手动set 即
  • Head First设计模式——策略模式

    Head First设计模式 是一本介绍设计模式的书籍 书中的设计模式主要是用Java语言进行实现 由于本人对C 比较熟悉 因此在阅读这本书籍时 尽自己所能 用C 重新去实现书中所涉及到的设计模式 若有错误或需要进一步讨论之处 望阅览者不吝
  • Uniapp 解决组件在官方文档不支持的事件上,接收小程序原生组件事件

    现在需要在抖音小程序上使用加粉丝群功能 官方 button 有自带这个功能 但是 Uniapp 官网并没有支持 一个是 open type 类型 一个是回调事件 bindjoingroup
  • 用Python做一个CMD命令 很简单我教你自己做一个命令行!

    目录 运用到的库 1 click库 2 作者自己的库 正式开始 hello py winOS py 添加变量环境 简介 大家好我是PYmili 大家都应该会CMD命令吧 什么你不会 看连接 CMD命令大全 大家肯定跟我一样 懒得记 那我就想

随机推荐

  • POSTING_INTERFACE_DOCUMENT解决特别总账'W'类型的过账问题

    Error F5246 Special G L transactions of type are not supported is being raised when trying to post a document via BAPI i
  • Springboot中Filter如何使用

    一 在初始化配置时指定Filter 1 假设自定义一个LoggingFilter 它必须实现Filter接口 public class LoggingFilter implements Filter Override public void
  • 毕业设计-基于机器视觉的直道车道线识别技术-OpenCV

    目录 前言 课题背景和意义 实现技术思路 一 边缘检测 二 ROI 区域确定 三 基于 Hough 变换车道线识别 四 车道线拟合 代码部分 实现效果图样例 最后 前言 大四是整个大学期间最忙碌的时光 一边要忙着备考或实习为毕业后面临的就业
  • 关于微信H5自动播放视频-canvas实现逐帧动画效果加音频

    项目需求 用户进入页面自动播放一段小视频 解决方案一 利用 JS reload 之后执行 video play 和 video autoplay 都只能在WEB段实现 但是到了移动端就执行不了 因为项目应用了微信的JS SDK 所以只需要做
  • dereferencing type-punned pointer will break strict-aliasing rules

    最近遇到了一个编译告警 严格别名和类型双关 整理一下相关的材料 strict aliasing 以下问题摘自1 I have the following questions If I leave the code with this war
  • FFmpeg入门详解之70:获取音视频流信息(Metadata)

    用FFmpeg获取视频流 音频流的信息 编码格式 分辨率 帧率 播放时长 简介 我们经常需要知道一个媒体文件所包含的媒体流的信息 比如文件格式 播放时长 码率 视音频编码格式 视频分辨率 帧率 音频属性等信息 如何使用FFmpeg API获
  • 猿人学js混淆-源码乱码解法总结

    猿人学js混淆 源码乱码解法总结 网址 解法 心得 网址 js混淆 源码乱码网址 解法 我是在360浏览器下打开网址 进入审查元素 打开第2页 发现请求网址为 http match yuanrenxue com api match 1 pa
  • 阿里云Redis开发规范

    开发十年 就只剩下这套Java开发体系了 gt gt gt 一 键值设计 1 key名设计 1 建议 可读性和可管理性 以业务名 或数据库名 为前缀 防止key冲突 用冒号分隔 比如业务名 表名 id ugc video 1 2 建议 简洁
  • 十. Kubernetes 核心配置文件与kubelet命令

    目录 一 核心组件与对应的配置文件 二 kubelet 配置文件 常用命令 一 核心组件与对应的配置文件 在使用k8s时 内部有多个核心组件例如用来接收请求的apiServer 解析请求存储etcd的ControllerManage 用来存
  • C++模板类的使用以及运算符重载的实现

    一 类模板及运算符重载的实现 如同函数模板一样 使用类模板使用户可以为类定义一种模式 使得类中的某些数据成员 某些成员函数的参数 某些成员函数的返回值能取任意类型 类模板是对一批仅仅成员数据类型不同的类的抽象 程序员只要为这一批类所组成的整
  • 简明区块链原理

    链客 专为开发者而生 有问必答 此文章来自区块链技术社区 未经允许拒绝转载 区块链 应有特质 使用了具有 哈希链 下文有解释 形式的数据结构保存基础数据 有多个结点参与系统运行 分布式 通过一定的协议或算法对于基础数据的一致性达成共识 共识
  • R语言优雅的修改列名称

    说实话 我一直没有搞懂R语言的dpyr包的rename是怎么用的 很奇怪 我一直用不好这个函数 或者说 我就不太喜欢他这个更改表格列名称的方式 但是我今天在stackoverflow上看到了一个人是这么用的 非常的amazing 介绍 在修
  • JAVA中Object类的toString()方法

    toString public String toString 返回该对象的字符串表示 通常 toString 方法会返回一个 以文本方式表示 此对象的字符串 结果应是一个简明但易于读懂的信息表达式 建议所有子类都重写此方法 Object
  • vxe-table 固定列滚动完成后没有对齐

    vxe table 固定列滚动完成后没有对齐 默认情况下 虚拟滚动是自动开启的 当行数超过设置的 scroll y gt 时 就会自动触发虚拟渲染 即只渲染可视区内的数据 所以要想将性能达到最优 应该确保可视区内的显示条数尽可能减少 建议在
  • C/C++临时变量详解

    临时变量 临时变量是一种只在调用期间有效 且具有常性的变量 Date d1 2022 报错 因为该语句会先将2022赋值给临时变量 而临时变量是const的 无法直接赋值给d1 因为这是权限的放大 不合法 这段代码就是正确的 const D
  • Java中Robot类详解

    概述 Java中Robot类位于java awt Robot 该类用于为测试自动化 自运行演示程序和其他需要控制鼠标和键盘的应用程序生成本机系统输入事件 Robot类的主要目的是便于Java平台实现自动测试 Robot可以模拟鼠标和键盘的输
  • Confluence 6 缓存性能优化

    Confluence 的运行状态与缓存状态有这密切的关系 针对 Confluence 的管理员来说 尤其是大型站点的 Confluence 管理员 设置好缓存尤其显得关键 希望修改缓存的大小 进入 gt 基本配置 General Confi
  • 并行求和算法实现

    题目描述 有 N N N 个处理器 现对 N N N 个数求和 要求每个处理器中都保持全和 有两个算法可以实现 蝶式求和算法 重复计算元素的求和 共需要 l
  • cefsharp 在高DPI下闪烁的问题

    今天有客户朋友说程序在他的surface下界面很闪烁 搜索了相关的资料 初步判定是DPI引起的问题 但也有可能是cefsharp 51版本在WIN10上面没有禁用GPU加速 苦于没有环境测试 所以抱着尝试的心态让他做了如下设置 结果程序正常
  • js数组或对象除去重复元素的四种方法

    1 利用对象的属性名来存储不重复的元素或者说利用对象的属性名来筛选重复的元素 let arr 0 2 2 3 4 5 3 3 5 4 l a p l p a let obj let arrs let arrLength arr length