位置: 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)

  • 礼物包装方法最简单的教程

    礼物包装方法最简单的教程

  • bilibili怎么删视频(比例比例怎么删视频)

    bilibili怎么删视频(比例比例怎么删视频)

  • vivoz3i为什么设置里没有OTG(vivoz3屏幕设置)

    vivoz3i为什么设置里没有OTG(vivoz3屏幕设置)

  • 手机12306怎么支付不了(手机12306怎样绑定支付宝)

    手机12306怎么支付不了(手机12306怎样绑定支付宝)

  • iphone8实况壁纸不动(苹果8实况照片怎么弄动态壁纸)

    iphone8实况壁纸不动(苹果8实况照片怎么弄动态壁纸)

  • 苹果x隐藏照片怎么恢复(苹果手机里的照片怎么隐藏)

    苹果x隐藏照片怎么恢复(苹果手机里的照片怎么隐藏)

  • 12306人脸识别不能通过怎么办(12306人脸识别不是本人)

    12306人脸识别不能通过怎么办(12306人脸识别不是本人)

  • 安卓手机越来越卡怎么办(安卓手机越来越贵)

    安卓手机越来越卡怎么办(安卓手机越来越贵)

  • qq表情doge什么意思(qq里面doge表情是什么意思)

    qq表情doge什么意思(qq里面doge表情是什么意思)

  • 虚拟桌面有什么用(虚拟桌面什么意思)

    虚拟桌面有什么用(虚拟桌面什么意思)

  • 微信号只能是英文和数字吗(微信号只能是英文吗为什么)

    微信号只能是英文和数字吗(微信号只能是英文吗为什么)

  • 浏览不良网站对手机有什么影响呢(浏览不良网站对个人有什么影响)

    浏览不良网站对手机有什么影响呢(浏览不良网站对个人有什么影响)

  • 京东pop和自营的区别(京东自营和pop店铺是什么意思啊)

    京东pop和自营的区别(京东自营和pop店铺是什么意思啊)

  • 爱奇艺几个设备同时在线(爱奇艺几个设备在哪查)

    爱奇艺几个设备同时在线(爱奇艺几个设备在哪查)

  • 快手每天关注上限多少(快手每天关注上限是多少人)

    快手每天关注上限多少(快手每天关注上限是多少人)

  • 苹果6s plus屏幕多大(苹果6splus屏幕多大尺寸)

    苹果6s plus屏幕多大(苹果6splus屏幕多大尺寸)

  • mate30pro和mate30的区别(mate30pro和mate30哪个好)

    mate30pro和mate30的区别(mate30pro和mate30哪个好)

  • 后置四摄像头有什么用(后置四摄有什么用)

    后置四摄像头有什么用(后置四摄有什么用)

  • 淘宝退款会影响卖家么(淘宝退款会影响信誉吗?)

    淘宝退款会影响卖家么(淘宝退款会影响信誉吗?)

  • qq群怎么删除聊天记录让别人也看不到(qq群聊怎么删掉)

    qq群怎么删除聊天记录让别人也看不到(qq群聊怎么删掉)

  • 荣耀9x可以分屏吗(荣耀9x分屏变成了浮窗)

    荣耀9x可以分屏吗(荣耀9x分屏变成了浮窗)

  • 华为商城支持七天无理由退货吗(华为商城支持花呗吗)

    华为商城支持七天无理由退货吗(华为商城支持花呗吗)

  • 手机上怎么交养老保险(手机上怎么交养老保险微信)

    手机上怎么交养老保险(手机上怎么交养老保险微信)

  • 小米8se外壳什么材质(小米8se好看的手机壳)

    小米8se外壳什么材质(小米8se好看的手机壳)

  • ps4蜘蛛侠中文设置(ps4蜘蛛侠如何设置简体中文)

    ps4蜘蛛侠中文设置(ps4蜘蛛侠如何设置简体中文)

  • 【Mac显示隐藏文件】苹果Mac操作系统下怎么显示隐藏文件(macbook显示隐藏文件)

    【Mac显示隐藏文件】苹果Mac操作系统下怎么显示隐藏文件(macbook显示隐藏文件)

  • syslog介绍(二):Linux下syslog基本配置(syslog使用)

    syslog介绍(二):Linux下syslog基本配置(syslog使用)

  • 所得税汇算清缴时间期限
  • 微信支付宝等三方支付平台余额属于货币资金吗
  • 教育费附加的计征依据包括
  • 个人独资企业税种有哪些
  • 研发费用加计扣除是什么意思啊
  • 个体户没做过账怎么办
  • 税控盘怎么注销需要带什么东西
  • 30万的车税可以抵多少
  • 土地使用税退税账务处理
  • 购货无法取得发票财务如何处理
  • 融资租入的企业有哪些
  • 提供应税服务营改增的应税服务不包括什么
  • 地税没报税怎么办
  • 营改增后水费差额征税账务处理怎么做?
  • 什么是工会经费返还
  • 有收入零申报要紧吗
  • 水资源税的纳税义务人
  • 社会团体收取的会费可以用于哪些方面
  • 红冲发票显示发票状态不正常
  • 补缴以前年度的印花税账务处理
  • 一般纳税人资格证明在哪里开具
  • 商业健康保险税优码
  • 输入法自定义按键位置
  • SWNETSUP.EXE - SWNETSUP是什么进程 有什么用
  • 房屋租赁费应如何缴纳
  • 政府补助计量的基础是
  • 税务部门罚没收入计入什么科目
  • 经营租入的设备计入什么科目
  • 收到对方公司开出发票如何做账
  • 三七粉的功效与作用及正确吃法
  • 贴吧热门评论
  • 什么样的企业是好企业,什么样的员工是好员工
  • 公司承担的社保公积金怎么做账
  • 收购农产品进项税抵扣税率是多少
  • win7纯净版系统安装教程
  • php延迟2秒执行
  • 酒店没有营业执照可以举报吗?
  • php获取地理位置
  • 股东分红会计分录摘要
  • 原材料按计划成本核算例题
  • 【深度学习】详解 MAE
  • chat top
  • 建材公司成本率一般多少
  • 帝国cms为什么安装不了
  • 公司买办公用品是谁的工作
  • 进项税大于销项税怎么结转
  • 开了红字发票申请还要做进项税转出吗
  • 付款后发票的扩张怎么开
  • 交强险怎么报警
  • 内账的账务处理
  • sqlmap暴力破解
  • Win2003系统下SQL Server 2008安装图解教程(详细图解)
  • 冲销上个月成本的会计分录
  • 未分配利润是否可以全部分红
  • 账务核对包括哪些内容
  • 公司账户资金转个人账户
  • 土地出让金如何核算
  • 税后扣税
  • 车间不生产折旧计提放哪里
  • 年化率23%是几分利息
  • 事业单位打款多久到账
  • sql中出现将截断字符串或二进制
  • windows7怎么说
  • windows server 2003如何安装
  • upd什么意思
  • windows10cortana搜索框
  • ubuntu18.04配置
  • win7系统cmd命令大全
  • win7系统升级win10教程
  • win8.1关机没反应
  • Win8出现奇怪爆音的完美解决方法
  • Extjs的FileUploadField文件上传出现了两个上传按钮
  • 怎么做小地图图片呢
  • 手机背光面板
  • shell循环结构
  • 用python抓取数据
  • unity 3d完全自学教程
  • Android EventBus实战
  • 江苏城乡医疗保险网上缴费2024年
  • 浙江省税务局领导介绍
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设