位置: 编程技术 - 正文

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要怎么学)

  • 餐饮娱乐服务费进项税不能从销项税额抵扣
  • 内账收入按实际收到确认吗
  • 增值税纳税申报表附列资料(二)
  • 企业会计准则和新会计准则的区别
  • 援企稳岗补贴的申请理由
  • 有两种税率的如何填申报表
  • 企业的日常经营活动主要包括哪三个经营过程
  • 代理记账有什么风险吗
  • 企业走账的会计处理
  • 现金支付用什么科目
  • 建筑施工企业质量体系环境包括
  • 增值税欠缴税会不会影响企业的信用
  • 收到员工的罚款钱怎么写分录
  • 公司账户转个人账户限额
  • 企业所得税申报时间
  • 差额纳税怎么记账
  • 白蚁防治费怎么计算
  • 报废固定资产增值税税率
  • 会议费增值税专用发票税率
  • 自然人出租房屋房产税
  • 坏账准备核销和转销的区别
  • 停车场领的定额发票要怎么报税?
  • 收到工伤保险的发票
  • 利息支出为什么不是经营成本
  • 土地租赁摊销年限按合同年限
  • 开机默认开启数字键
  • 什么是盈余公积和资本公积
  • 电子承兑汇票怎么用
  • 银行手续费发票税率
  • php unit
  • 公司之间转移固定资产
  • 日记账登记错了怎么办
  • win10补丁kb5005543
  • linux双ip路由设置方法
  • 如何用wordpress
  • 附有退回条件的销售商
  • 甲供材料增值税
  • wordpress如何使用
  • 支付水电费增值税账务处理
  • 临时工工资计入哪里
  • 共管账户和联名账户
  • cuppath
  • 现金股利什么时候到账
  • 工业企业成本核算的一般程序
  • 综合所得个税计算例题
  • 资产负债表季报是累计三个月数据吗
  • 工资以现金形式发放英文
  • 代数分配法的优缺点和适用范围
  • 企业贴现会计分录
  • 专家评审费如何入账
  • 会计中制造费用包括哪些内容
  • 购买产品样品计入什么科目
  • 应收账款多久收不回来作为坏账
  • 哪些项目的进项可以抵扣
  • 普通发票作废如何操作
  • 外账和内账怎么配合做账
  • 预收账款怎么做账
  • 几个常见的收敛级数
  • 如何彻底关闭mac电脑app
  • centos安装后配置
  • schupd.exe - schupd是什么进程 有什么用
  • linux如何使用uname命令
  • win7 0x80070002处理方法
  • win1010586升级到最新
  • centos安装命令yum
  • perl如何使用
  • opengl绘图
  • perl 获取参数
  • UNITY开发数字孪生
  • qt配置opengl
  • 微信小程序图片加载不出来
  • javascript提交数据
  • node.js视频教程
  • wordpress单页面店铺
  • javascript文字特效
  • js函数总结
  • python+Django+apache的配置方法详解
  • js遍历foreach
  • 浦东税务15所
  • 税务风险管理指引
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设