位置: IT常识 - 正文

JS实现数组去重的八种方法(实用)(js 数组去重的四种方法)

编辑:rootadmin
JS实现数组去重的八种方法(实用) 前言

推荐整理分享JS实现数组去重的八种方法(实用)(js 数组去重的四种方法),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js中数组去重的方法,js写数组去重,js如何数组去重,js数组去重indexof,js 数组去重的四种方法,js 数组去重,js中数组去重复的方法有哪些,js 数组去重的四种方法,内容如对您有帮助,希望把文章链接给更多的朋友!

js数组去重是比较常见的数组操作方式之一,网上有很多关于数组去重的博客文章,方法各式各样,但有些方法实用性很差,很容易造成不必要的麻烦,所以我们需要去其糟粕取其精华,下面我们就整理一些比较实用的数组去重方法。

Methods 1:利用双重for循环JS实现数组去重的八种方法(实用)(js 数组去重的四种方法)

思路:定义一个新数组,并存放原数组的第一个元素,然后将元素组一一和新数组的元素对比,若不同则存放在新数组中。

function unique(arr) { let newArr = [arr[0]]; for (let i = 1; i < arr.length; i++) { let repeat = false; for (let j = 0; j < newArr.length; j++) { if (arr[i] === newArr[j]) { repeat = true; break; } } if (!repeat) { newArr.push(arr[i]); } } return newArr;}console.log(unique([1, 1, 2, 5, 5, 3, 4, 9, 6, 3, 4]));// 结果是[1, 2, 5, 3, 4, 9, 6]Methods 2:利用对象

思路:利用对象属性存在的特性,如果没有该属性则存入新数组

function unique(arr) { const newArr = [] const obj = {} arr.forEach(item => { if (!obj[item]) { newArr.push(item) obj[item] = true } }) return newArr } console.log(unique([1, 1, 2, 5, 5, 3, 4, 9, 6, 3, 4])) // 结果是[1, 2, 5, 3, 4, 9, 6]Methods 3:利用数组的indexOf方法

思路:新建一个空数组,遍历需要去重的数组,将数组元素存入新数组中,存放前判断数组中是否已经含有当前元素,没有则存入。此方法也无法对NaN去重。

var arr = [1,9,8,8,7,2,5,3,3,3,2,3,1,4,5,444,55,22];function unique(arr) { //定义一个新的临时数组 var newArr=[]; //遍历当前数组 for(var i=0;i<arr.length;i++) { //如果当前数组的第i已经保存进了临时数组,那么跳过, //否则把当前项push到临时数组里面 if(newArr.indexOf(arr[i]) === -1) { //indexOf() 判断数组中有没有字符串值,如果没有则返回 -1 newArr.push(arr[i]); } } return newArr } var arr2 = unique(arr); console.log(arr2); //[ 1, 9, 8, 7, 2, 5, 3, 4, 444, 55, 22]Methods 4:利用数组的includes方法

思路:此方法逻辑与indexOf方法去重异曲同工,只是用includes方法来判断是否包含重复元素。

function unique(arr) { var newArr = [] for (var i = 0; i < arr.length; i++) { if (!newArr.includes(arr[i])) { newArr.push(arr[i]) } } return newArr}console.log(unique([1,5,1,5,3,74,32,7,32,6,9,4,7,4]));// 结果是[1, 5, 3, 74, 32, 7, 6, 9, 4]Methods 5:利用数组的 filter 和 includes方法

同理,filter+indexOf也可

function unique(arr) { var newArr = [] newArr = arr.filter(function (item) { return newArr.includes(item) ? '' : newArr.push(item) }) return newArr}console.log(unique([1,5,1,5,3,74,32,7,32,6,9,4,7,4]));// 结果是[1, 5, 3, 74, 32, 7, 6, 9, 4]Methods 6:利用数组的 forEach 和 includes方法function unique(arr) { let newArr = []; arr.forEach(item => { return newArr.includes(item) ? '' : newArr.push(item); }); return newArr;}console.log(unique([1,1,2,5,6,3,5,5,6,8,9,8]));// 结果是[1, 2, 5, 6, 3, 8, 9]Methods 7:利用数组的 splice 方法。function unique(arr){ for(var i=0;i<arr.length;i++){ for(var j=i+1;j<arr.length;j++){ if(arr[i]==arr[j]){ //如果第一个等于第二个,splice方法删除第二个 arr.splice(j,1); j--; } } } return arr;}var arr = [1,1,2,5,6,3,5,5,6,8,9,8];console.log(unique(arr))//[ 1, 2, 5, 6, 3, 8, 9 ]Methods 8:利用Set()+Array.from()

代码最简洁,原理:

Set对象:是值的集合,你可以按照插入的顺序迭代它的元素。 Set中的元素只会出现一次,即Set中的元素是唯一的。Array.from() 方法:对一个类似数组或可迭代对象创建一个新的,浅拷贝的数组实例。function unique(arr){ return Array.from(new Set(arr))}var arr = [1,1,2,9,6,9,6,3,1,4,5];console.log(unique(arr))//[ 1, 2, 9, 6, 3, 4, 5 ]
本文链接地址:https://www.jiuchutong.com/zhishi/300269.html 转载请保留说明!

上一篇:学习CSS3,模拟春雪漫天飘的动画效果(css3的模块结构和应用)

下一篇:SpringIOC和AOP介绍(spring的aoc和aop)

  • 微博营销之怎么才能把粉丝变成忠实客户(微博营销怎么推荐产品)

    微博营销之怎么才能把粉丝变成忠实客户(微博营销怎么推荐产品)

  • 合肥地铁可以刷支付宝吗(合肥地铁可以刷京津冀一卡通吗)

    合肥地铁可以刷支付宝吗(合肥地铁可以刷京津冀一卡通吗)

  • 苹果手机电池健康掉的太快怎么办(苹果手机电池健康怎么保持)

    苹果手机电池健康掉的太快怎么办(苹果手机电池健康怎么保持)

  • 淘宝退货写纸条怎么写(淘宝退货留纸条怎么写)

    淘宝退货写纸条怎么写(淘宝退货留纸条怎么写)

  • 电脑钉钉麦克风没声音(电脑钉钉麦克风怎么设置)

    电脑钉钉麦克风没声音(电脑钉钉麦克风怎么设置)

  • 充电宝输出电压多少伏(充电宝输出电压不够怎么办)

    充电宝输出电压多少伏(充电宝输出电压不够怎么办)

  • 快手为什么会无缘无故的扣钱(快手为什么会无缘无故涨粉)

    快手为什么会无缘无故的扣钱(快手为什么会无缘无故涨粉)

  • 机械硬盘有必要装吗(机械硬盘有必要gpt分区吗)

    机械硬盘有必要装吗(机械硬盘有必要gpt分区吗)

  • 小红书怎么拉进度条(小红书怎么拉进粉丝群)

    小红书怎么拉进度条(小红书怎么拉进粉丝群)

  • cad构造线快捷键命令(cad中的构造线快捷键)

    cad构造线快捷键命令(cad中的构造线快捷键)

  • 开飞行模式能看离线视频吗(开飞行模式能看见未接电话吗)

    开飞行模式能看离线视频吗(开飞行模式能看见未接电话吗)

  • iphone备用电量怎么用(苹果手机备用电量代码)

    iphone备用电量怎么用(苹果手机备用电量代码)

  • 计算机的内存储器一般是指(计算机的内存储蓄比外存储蓄)

    计算机的内存储器一般是指(计算机的内存储蓄比外存储蓄)

  • 京东海外自营和京东自营有什么区别(京东海外自营和京东自营哪个好)

    京东海外自营和京东自营有什么区别(京东海外自营和京东自营哪个好)

  • vbchar和string的区别(vb中string和integer的区别)

    vbchar和string的区别(vb中string和integer的区别)

  • arserver是什么应用(arserver下载)

    arserver是什么应用(arserver下载)

  • 电脑上怎么画直线(电脑怎么画直方图)

    电脑上怎么画直线(电脑怎么画直方图)

  • 华为设置上滑返回(华为怎么设置往上滑返回键)

    华为设置上滑返回(华为怎么设置往上滑返回键)

  • 手机怎么激活信用卡(手机怎么激活短信功能)

    手机怎么激活信用卡(手机怎么激活短信功能)

  • 华为jsn tloo是什么型号(华为jsnaloo是什么型号)

    华为jsn tloo是什么型号(华为jsnaloo是什么型号)

  • 什么原因电源板坏了(电源板损坏原因)

    什么原因电源板坏了(电源板损坏原因)

  • 天猫精灵怎么连接网络(天猫精灵怎么连接蓝牙)

    天猫精灵怎么连接网络(天猫精灵怎么连接蓝牙)

  • 趣步怎么不能置换了(趣步怎么了)

    趣步怎么不能置换了(趣步怎么了)

  • 小度音箱一天耗多少电(小度智能音箱续航时长)

    小度音箱一天耗多少电(小度智能音箱续航时长)

  • 米家智能风扇怎么连接手机(米家智能风扇怎么样)

    米家智能风扇怎么连接手机(米家智能风扇怎么样)

  • 手机听不到对方说话怎么回事(手机听不到对方说话)

    手机听不到对方说话怎么回事(手机听不到对方说话)

  • 会计核算职能有哪些特征
  • 公司费用票
  • 制造费用多结转了下月如何调整
  • 企业所得税财务费用借款利息扣除标准
  • 小型微利企业申请
  • 小企业无形资产有
  • 可供分配利润包含哪些
  • 印花税计提多了怎样更正
  • 其他应收款在什么方
  • 企业缴纳房产税的依据
  • 营改增后新开公司如何报地税?
  • 增值税专用发票抵扣期限
  • 税控盘月度统计表怎么打印
  • 代扣代缴个人所得税手续费是否缴纳增值税
  • 公司委托法人代收款
  • 浅谈收入与成本的关系
  • 现金盘盈盘亏怎么计算
  • 基金投资了能随时取出吗
  • 银行贷款的坏账是什么意思
  • 原材料费用的分配
  • 用于非应税项目的购进货物或应税劳务
  • 华为手机屏幕下的三个功能键设置方法
  • qqprotect.exe是什么进程?怎么结束此进程?
  • win11怎么关闭进程
  • 外贸公司收汇可以收运费吗
  • 递延收益为什么计税基础为0
  • PHP:oci_internal_debug()的用法_Oracle函数
  • mac补丁安装步骤
  • 库存商品的主要类型
  • 2019年下半年中小学教师资格考试综合素质试题
  • windows7旗舰版最新版本
  • 货运代理开票
  • vue有哪些方法
  • flex布局用法
  • php强制下载文件在哪
  • 增值税减免怎么填写
  • 个体工商户的酒店增值税率是多少
  • 固定资产租赁费发票增值税税率
  • 开发商需要缴纳保证金
  • 请问如何在
  • 禁止DedeCMS未审核文档支持动态浏览方法
  • 个税申报系统累计收入怎么算
  • 间接费用允许调整吗
  • 计提以前年度的企业所得税
  • 生产成本制造费用借贷方向
  • 在sysservers中找不到服务器
  • sql server存储过程写法
  • 转让无形资产使用权
  • 单位集体旅游算工资吗
  • 商贸公司批发零食怎么样
  • 行政事业单位拨付给企业的财政补助款用交增值税吗
  • 高危险工作人员有什么意外险
  • 银行贷款信用贷
  • 服务类企业主要经营范围
  • 金蝶主要业务及软件产品
  • 原材料暂估入库成本结转处理
  • 无形资产出资入股的会计处理
  • 税金及附加科目借贷方向
  • Microsoft SQLServer的版本区别及选择
  • blos是什么意思
  • lsass exe
  • linux vim 查找替换
  • 雨林木风 winxp sp3 安装版 ys8.0
  • win7系统管理员密码
  • nodejs web3
  • node 内存泄漏
  • javascript零基础
  • html+css网站设计基础教程
  • ugy与ngy
  • 简单的比较
  • 农产品初加工有哪些
  • 电子税务局申报截止日期
  • 税务青年要担当
  • 出口退税报关单在哪里打印
  • 资源税的税目,税率依照税目税率表执行
  • 合伙企业可以融资吗
  • 营业税发票现在可以冲红么
  • 南通医保2023年新政策
  • 消费税征税环节
  • 所得税与增值税区别
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设