位置: 编程技术 - 正文

JavaScript学习笔记之数组去重(javascript如何学)

编辑:rootadmin

推荐整理分享JavaScript学习笔记之数组去重(javascript如何学),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:javascript怎么学,javascript教程完整版,javascript基础笔记,javascript基础笔记,javascript教程推荐知乎,javascript教程推荐知乎,javascript学习指南,javascript教程推荐知乎,内容如对您有帮助,希望把文章链接给更多的朋友!

推荐阅读:JavaScript学习笔记之数组的增、删、改、查

JavaScript学习笔记之数组求和方法

JavaScript学习笔记之数组随机排序

话说面试常会碰到面试官会问JavaScript实现数组去重的问题,最近刚好在学习有关于JavaScript数组相关的知识,趁此机会整理了一些有关于JavaScript数组去重的方法。

下面这些数组去重的方法是自己收集和整理的,如有不对希望指正文中不对之处。

双重循环去重

这个方法使用了两个for循环做遍历。整个思路是:

构建一个空数组用来存放去重后的数组

外面的for循环对原数组做遍历,每次从数组中取出一个元素与结果数组做对比如果原数组取出的元素与结果数组元素相同,则跳出循环;反之则将其存放到结果数组中

代码如下:

假设我们有一个这样的数组:

据说这种方法比较耗时,费性能。简单做个测试(测试方法写得比较拙逼):

在Chrome控制器运行上面的代码,测试双重循环去重所费时间:ms。

上面的方法可以使用forEach()方法和indexOf()方法模拟实现:

通过unique1.apply(arr)或unique1.call(arr)调用。不过这种方法效率要快得多,同样的上面测试代码,所费时间ms,几乎快了一半。

排序遍历去重

先使用sort()方法对原数组做一个排序,排完序之后对数组做遍历,并且检查数组中的第i个元素与结果数组中最后一个元素是否相同。如果不同,则将元素放到结果数组中。

例如:

这种方法有两个特色:

去重后的数组会做排序,主要是因为原数在去重前做了排序

JavaScript学习笔记之数组去重(javascript如何学)

去重后的数组,与数字相同的数字字符无法区分,比如'1'和1

使用同样的方法,测试所费时间:ms。

对象键值对法

这种去重方法实现思路是:

创建一个JavaScript对象以及新数组

使用for循环遍历原数组,每次取出一个元素与JavaScript对象的键做对比

如果不包含,将存入对象的元素的值推入到结果数组中,并且将存入object对象中该属性名的值设置为1

代码如下:

运行前面的示例:

同样的,不同的键可能会被误认为一样;例如: a[1]、a["1"] 。这种方法所费时间:ms。 这种方法所费时间是最短,但就是占用内存大一些。

除了上面几种方法,还有其他几种方法如下:

Chrome测试结果

同样的,1和'1'无法区分。

Chrome测试结果:

同样的,类似于1和'1'无法区分。所费时间:ms。

测试结果如下:

所费时间:ms。

测试结果:

所费时间:ms。

方法虽然很多种,但相比下来,下面这种方法是较为优秀的方案:

但在ES6去重还有更简单,更优化的方案,比如:

以上所述是小编给大家介绍的JavaScript学习笔记之数组去重,希望对大家有所帮助!

JavaScript学习笔记之取数组中最大值和最小值 推荐阅读:JavaScript学习笔记之数组的增、删、改、查JavaScript学习笔记之数组求和方法JavaScript学习笔记之数组随机排序在实际业务中有的时候要取出数

JS随机洗牌算法之数组随机排序 推荐阅读:JavaScript学习笔记之数组的增、删、改、查JavaScript学习笔记之数组求和方法JavaScript学习笔记之数组随机排序洗牌算法是一个比较形象的术语

JavaScript弹出对话框的三种方式 学习过js的小伙伴会发现,我们在一些实例中用到了alert()方法、prompt()方法、prompt()方法,他们都是在屏幕上弹出一个对话框,并且在上面显示括号内的

标签: javascript如何学

本文链接地址:https://www.jiuchutong.com/biancheng/375938.html 转载请保留说明!

上一篇:JavaScript学习笔记之数组随机排序(javascript教程完整版)

下一篇:JavaScript学习笔记之取数组中最大值和最小值(javascript要怎么学)

  • 初级会计职称能加多少工资
  • 残疾人保障金的工资按实发还是应发
  • 普通发票为什么只能领一张
  • 小规模纳税人如何转一般纳税人
  • 小规模纳税人滚动累计
  • 查账征收企业所得税年报怎么填
  • 培训产生的费用
  • 税控盘备案在电子税务局操作流程
  • 小企业取得存货计量的原则
  • 行政单位的财务报告包括财务报表和财务情况说明书
  • 通行费进项抵扣条件
  • 跨年发票企业所得税
  • 非住宅过户税费标准最新
  • 预提工程成本的会计分录
  • 公司发生的费用需要交税吗
  • 年末会计账上应该注意哪些
  • 股票派息后会除权吗
  • 固定资产什么时候增加
  • 午餐补贴多少钱
  • 什么叫抵免
  • 材料成本的核算方法有哪些
  • 去年多计提的个税如何处理
  • 赊销商品填制什么科目
  • 建筑业总产值的统计执法检查内容
  • 公司的实收资本是借款,但是利息由公司付,会计怎么做账
  • 销售设备并提供安装服务增值税税率
  • 使用linux命令
  • word无法创建工作环境
  • php获取网页视频地址
  • 布拉索夫地图
  • 股权转让个人所得税优惠政策
  • 记账凭证账务处理步骤
  • 企业合并支付的资产评估费计入
  • 餐厅手撕发票
  • 摄像头标定方法
  • 中兴网管操作手册
  • 固定资产盘盈为什么计入以前年度损益调整
  • 季节性用工法律规定
  • Sqlite 常用函数 推荐
  • 金蝶标准版怎么查应收应付款
  • mysql存储语句
  • MySQL数据库性能优化
  • 税金及附加与应交税金的关系
  • 企业之间借款利息开票编码
  • 递延所得税资产和负债账务处理
  • 新增项目和延续项目
  • 豆制品属于农副产品吗为什么
  • 企业所得税如何抵扣
  • 结转费用后利润怎么算
  • 进项转出再转入
  • 法人存入公户的钱摘要
  • 行政单位年结
  • 存货科目包括哪几类
  • 数据库预处理语句
  • mysql 5.7.17 winx64安装配置图文教程
  • 猛料高手
  • 重装系统重启后怎么操作
  • wcu.exe是什么
  • vs显示进程已退出
  • win8显示桌面图标
  • win1020h2正式版
  • winxp如何打开控制面板
  • win7如何设置屏幕不黑屏
  • cocos预加载
  • javascript全选反选
  • 利用css样式控制文本的字体属性是什么
  • OSG 砖块 shader 例子 GLSL
  • iframe transparent透明背景方法
  • oracle批处理语句
  • python2与python3的区别
  • js数组添加元素的方法
  • bootstrap boosting
  • jquery实例
  • Python Requests 基础入门
  • 国家税务局上海电子税务局app
  • 全国企业信用信息系统网官网
  • 电子发票美元如何查询
  • 开票日期是今年但是业务是去年
  • 我国近十年财政支出结构占比
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设