javaScript去重的11种方法
前言
去重是开发和面试中经常遇到的问题,下面是总结的 11 种去重方法
方法
示例数组
var arr = [1, 2, 4, 5, 5, 2, 1, 1, 4, 6]
set + 解构赋值
这种方法利用了 set 成员唯一的特征和扩展运算符方法实现
function fn1() {
return ([...new Set(arr)]);
}
console.log(fn1());
forEach 循环 + indexOf
先使用 foreach 循环取到每一个元素,在这里也可以改成 for 循环的写法道理是一样的,取到每一个元素后取这个元素的 index 和循环中 index 比较是否一样,一样则 push()
function fn2() {
let temp = []
arr.forEach((item, index) => {
arr.indexOf(item) == index ? temp.push(item) : null
})
return temp
}
console.log(fn2());
filter 过滤
和上一种方法思路差不多,filter 相当于上面的步骤合并到一个方法中实现
function fn3() {
let temp = arr.filter((item, index) => {
return arr.indexOf(item) == index
})
return temp
}
console.log(fn3());
对象键值唯一性
对象的键值因为具有唯一性,所以可以将数组成员作为 key 保存起来,在数组全部循环过一次后,再循环取出对象的 key 添加到一个空白数组中,但是这种方法会导致取出的数组成员数据类型全部转换为文本类型。
function fn4() {
let obj = {}
let temp = []
arr.forEach((item, index) => {
obj[item] = index //这一步赋值value其实没有必要,因为最后使用不到
})
for (const key in obj) {
temp.push(key)
}
return temp
}
console.log(fn4());
双重 for 循环
外循环的作用是取到每一个元素,内循环的作用是将外循环取到的元素和其余的元素做对比,如果能取到一样的将后一个删除,要注意的是删除的话需要将内循环的计数 - 1,因为数组的长度也 - 1 了。
function fn5() {
let temp = arr
for (let i = 0; i < temp.length; i++) {
for (let j = i + 1; j < temp.length; j++) {
if (temp[i] === temp[j]) {
temp.splice(j, 1)
j--
}
}
}
return temp
}
console.log(fn5());
indexOf + lastIndexOf
这种方法的思路是如果一个元素查找她的索引,从前获得和从后获得的索引一样,则必然是唯一的,如果不一样说明有重复,删除最后一个并将计数 i-1。
function fn6(){
for(let i =0;i<arr.length;i++){
if(arr.indexOf(i)!=arr.lastIndexOf(i)){
arr.splice(arr.lastIndexOf(i),1)
i--
}
}
return arr
}
console.log(fn6());
sort + 循环
思路是先将数组的内容按照大小排序,然后从第一开始和后一个进行对比,如果一样说明是重复的,将重复的删除并计数 - 1。
function fn7() {
let temp = arr.sort((a, b) => {
return a - b
})
for (let i = 0; i < temp.length; i++) {
if (temp[i] === temp[i + 1]) {
temp.splice(i + 1, 1)
i--
}
}
return temp
}
console.log(fn7());
includes + 循环
思路是先创建一个新数组,然后循环取到每一个元素,如果该元素不在新数组中,就将其添加进去。
function fn8() {
let temp = []
for (let i = 0; i < arr.length; i++) {
if (!temp.includes(arr[i])) {
temp.push(arr[i])
}
}
return temp
}
console.log(fn8());
Map
Map 是 ES6 中特性,是一种字典的数据结构,和对象一样也具有 key 的唯一性
- map.set 设置 map 的 key
- map.has 检测是否含有指定的 key,返回一个布尔值
function fn9() {
let map = new Map();
let temp = []
for (let i = 0; i < arr.length; i++) {
if (!map.has(arr[i])) { //如果键值不存在,则写入这个键值并添加到数组
map.set(arr[i], false);
temp.push(arr[i]);
}
}
return temp;
}
console.log(fn9());
递归
这个方法和 sort 方法也许相似,先使用 sort 排序,但是是使用递归的思路从后到前删除相同的元素
function fn10() {
let len = arr.length;
let temp = arr.sort(function (a, b) {
return a - b;
});
function loop(index) {
if (index >= 1) {
if (temp[index] === temp[index - 1]) {
temp.splice(index, 1);
}
loop(index - 1)
}
}
loop(len - 1);
return temp;
}
console.log(fn10());
Reduce
reduce 的数组的累加器方法,在本例中 reduce 的第一个参数是一个函数,用来处理每一个元素,第二个参数是一个空数组作为容器,reduce 的循环开始,空数组会被带入 prev,判断 prev 中是否含有当前处理的元素 item,如果已经有了就不做处理,如果没有就将 prev 和 item 合并为一个数组,处理完毕后这个数组会被返回给 reduce 作为下一轮处理的第二个参数,依次循环,最后得到的就是去重后的数组
function fn11() {
return arr.reduce((prev, item) => {
return prev.includes(item) ? prev : [...prev, item]
}, []);
}
console.log(fn11());
总结
数组的去重方法有很多,在使用的时候需要根据自己的需求去选择,比如使用了 sort 的方法的去重只能使用在纯数字数组中,而对象键值去重数组后数组成员都是纯字符串等等。本篇只是简单的方法总结,还有一些没有举例,重点是解决问题思路
javaScript去重的11种方法的更多相关文章
- [转]JavaScript去重的6种方法
Array.prototype.unique1 = function() { var n = []; for(var i = 0; i < this.length; i++) { if (n.i ...
- JavaScript中数组去重的几种方法
JavaScript中数组去重的几种方法 正常情况下,数据去重的工作一般都是由后端同事来完成的,但是前端也要掌握好处理数据的能力,万一去重的工作交给我们大前端处理,我们也不能怂呀.现在我总结了一些去重 ...
- js中数组去重的几种方法
js中数组去重的几种方法 1.遍历数组,一一比较,比较到相同的就删除后面的 function unique(arr){ ...
- 在WebBrowser中执行javascript脚本的几种方法整理(execScript/InvokeScript/NavigateScript) 附完整源码
[实例简介] 涵盖了几种常用的 webBrowser执行javascript的方法,详见示例截图以及代码 [实例截图] [核心代码] execScript方式: 1 2 3 4 5 6 7 8 9 1 ...
- JS学习笔记——JavaScript继承的6种方法(原型链、借用构造函数、组合、原型式、寄生式、寄生组合式)
JavaScript继承的6种方法 1,原型链继承 2,借用构造函数继承 3,组合继承(原型+借用构造) 4,原型式继承 5,寄生式继承 6,寄生组合式继承 1.原型链继承. <script t ...
- python列表的11种方法
python列表的11种方法2017年11月24日 03:26:43 Milton-Long 阅读数:254版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.n ...
- python 3.x 字典的11种方法
python 3.x 字典的11种方法2017年11月25日 01:02:11 Milton-Long 阅读数:535 标签: python python字典方法 更多个人分类: python-学习之 ...
- Javascript 创建对象的三种方法及比较【转载+整理】
https://developer.mozilla.org/zh-CN/docs/JavaScript/Guide/Inheritance_and_the_prototype_chain 本文内容 引 ...
- List集合对象去重及按属性去重的8种方法-java基础总结系列第六篇
最近在写一些关于java基础的文章,但是我又不想按照教科书的方式去写知识点的文章,因为意义不大.基础知识太多了,如何将这些知识归纳总结,总结出优缺点或者是使用场景才是对知识的升华.所以我更想把java ...
随机推荐
- 论文解读(GROC)《Towards Robust Graph Contrastive Learning》
论文信息 论文标题:Towards Robust Graph Contrastive Learning论文作者:Nikola Jovanović, Zhao Meng, Lukas Faber, Ro ...
- [AcWing 87] 把字符串转换成整数
点击查看代码 class Solution { public: int strToInt(string str) { int k = 0; while (k < str.size() & ...
- 如何对用户的绑定的身份证真实性进行实名认证(java)
现在随着对用户实名制的要求,因此用户提交的身份证信息经查需要检查是否为真实信息,我们需要对用户提交的身份证信息进行核验,具体操作步骤如下: 第一步 到认证平台注册账号:云亿互通--实名认证服务 (yu ...
- DDoS攻击--Syn_Flood攻击防护详解(TCP)
https://blog.csdn.net/qq_34777600/article/details/81946514
- MySQL基准测试工具
一.基准测试 基准测试(benchmark)是针对系统设计的一种压力测试. 基准测试是简化了的压力测试. 1.1 常见指标 TPS QPS 响应时间 并发量 1.2 收集与分析数据脚本 收集数据的sh ...
- Flask_WTF实现表单
Flask_WTF实现表单可分为六个步骤: ①导入FlaskForm扩展包(from flask_wtf import FlaskForm) ②导入StringField,PasswordField, ...
- MAC M1安装多个JDK版本及动态切换
JDK版本下载 下载地址:https://www.azul.com/downloads/?package=jdk 筛选一下macOS的ARM 64-bit架构的JDK版本,下载对应版本即可.最好直接下 ...
- 2.26NK周赛
这场打的很烂,说明我对组合数学的掌握(二项式定理,以及递推式的思考方向)都不太好.而且,我做题的思路也很有问题.就是完全凭借灵感,自己没有脑子一样思路就被题目带跑了,根本跳不出来,看到题目也不会分析, ...
- Docker容器:将带UI的程序直接转为Web应用,so easy
摘要:使用Docker容器,将带UI的程序,直接转换为Web应用.很方便,跟大家分享一下. 本文分享自华为云社区<使用Docker容器,将带UI的程序,直接转为Web应用>,作者:tsjs ...
- mybatis if判断等于某个字符串
这种写法是错误的:在OGNL的表达式中,'true'会被解析成字符,因为java是强类型的 <if test="flag=='true' "> AND ho.id = ...