JavaScript数组去重的7种方式
1.利用额外数组
function unique(array) {
if (!Array.isArray(array)) return;
let newArray = [];
for(let i=0, len=array.length; i<len; i++) {
let itemAtIndex = array[i];
if (!newArray.includes(itemAtIndex)) { // newArray.indexOf(itemAtIndex) === -1
newArray.push(itemAtIndex);
}
}
return newArray;
}
2.indexOf与lastIndexOf
function unique(array) {
if (!Array.isArray(array)) return;
for(let i=0; i<array.length; i++) {
let itemAtIndex = array[i];
if (array.indexOf(itemAtIndex) !== array.lastIndexOf(itemAtIndex)) {
array.splice(i, 1);
i--; // array 与 array.length change
}
}
return array; // 顺序可能会改变
}
注: 利用额外数组配合indexOf与lastIndexOf 取出未重复出现的元素
function unique(array) {
if (!Array.isArray(array)) return;
let newArray = [];
for(let i=0, len=array.length; i<len; i++) {
let itemAtIndex = array[i];
if (array.indexOf(itemAtIndex) === array.lastIndexOf(itemAtIndex)) {
newArray.push(itemAtIndex);
}
}
return newArray;
}
3.filter
function unique(arr) {
return arr.filter(function(item, index, arr) {
// 取出元素, 该元素在数组中第一次出现的索引 === 当前索引值
return arr.indexOf(item, 0) === index;
});
}
4.双层for循环
function unique(array) {
if (!Array.isArray(array)) return;
for(var i=0; i<array.length; i++) {
for(var j=i+1; j<array.length; j++) {
if (array[j] === array[i]) {
array.splice(j, 1);
j--; // array 与 array.length change
}
}
}
return array;
}
5.利用sort排序后, 相邻元素不相等
function unique(array) {
if(!Array.isArray(array)) return;
array.sort();
for (let i=0; i<array.length; i++) {
if (i <= array.length-2) {
if (array[i+1] === array[i]) {
array.splice(i+1, 1);
i--; // array 与 array.length change
}
}
}
return array; // 顺序可能会改变
}
6.利用对象key唯一的特性(这个方法还能标记出重复元素的数量); 另, map原理与object一致
function unique(array) {
if (!Array.isArray(array)) return;
let obj = {};
for(let i=0, len=array.length; i<len; i++) {
let itemAtIndex = array[i];
obj[itemAtIndex] = '';
}
let newArray = [];
for(let key in obj) {
newArray.push(Number(key));
}
return newArray; // 顺序可能会改变
}
7.利用ES6 set
function unique(array) {
if (!Array.isArray(array)) return;
return Array.from(new Set(array)); // [...new Set(array)]
}
测试函数及测试用例
function ensureEqual(a, b, message) {
if (JSON.stringify(a) !== JSON.stringify(b)) {
console.log(`***测试失败, ${JSON.stringify(a)} 不等于 ${JSON.stringify(b)}, ${message}`);
}
};
ensureEqual(unique([1,2,3,3,4,4,5,5,6,1,9,3,25,4]), [1,2,3,4,5,6,9,25], 'test1');
以上就是JavaScript数组去重的较为常规的方式;其中,第3种比较不容易想到;另,由于业务中一般处理的都是相同类型的数据,因此这里数组里的数据统一为数值类型,并未做混合类型的考虑。
JavaScript数组去重的7种方式的更多相关文章
- js 数组去重的几种方式及原理
let arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,' ...
- javascript 数组去重的6种思路
前端在日常开发中或多或少都会碰到有对数据去重的需求,实际上,像是lodash这些工具库已经有成熟完备的实现,并且可以成熟地运用于生产环境.但是这并不妨碍我们从思维拓展的角度出发,看看去重可以用几种思路 ...
- JavaScript数组去重的几种方法
这个老问题,网上普遍都有了,为什么要再写一遍呢,主要是为了记个笔记... 遍历时搜索结果数组 思路很明确,如下 新建一个数组存放结果 循环遍历原数组,对于每一个元素,在结果数组中搜索是否存在 若不存在 ...
- JavaScript数组去重的10种方法
「数组去重」的确是个老生常谈的问题了,但是你真正的掌握了吗?平时开发中是不是用最简单粗暴的方法来去重?注意到它的性能问题了吗?当面试官对你回答的四个去重方法都不满意时你可以想出更简单且性能能更好的方法 ...
- javascript数组去重的3种方法
前言:这是笔者学习之后自己的理解与整理.如果有错误或者疑问的地方,请大家指正,我会持续更新! javascript数组去重 <!DOCTYPE html> <html> < ...
- JS 数组去重的几种方式
JS 常见的几种数组去重方法 一.最简单方法(indexOf 方法) 实现思路:新建一个数组,遍历要去重的数组,当值不在新数组的时候(indexOf 为 -1)就加入该新数组中: function u ...
- JavaScript数组去重的四种方法
今天,洗澡的想一个有趣的问题,使用js给数组去重,我想了四种方法,虽然今天的任务没有完成,5555: 不多说,po代码: //方法一:简单循环去重 Array.prototype.unique1 ...
- [转] JavaScript数组去重(12种方法)
数组去重,一般都是在面试的时候才会碰到,一般是要求手写数组去重方法的代码.如果是被提问到,数组去重的方法有哪些?你能答出其中的10种,面试官很有可能对你刮目相看.在真实的项目中碰到的数组去重,一般都是 ...
- reduce计算数组中每个元素出现的次数 数组去重的几种方式 将多维数组转化为一维
// js计算数组中每个元素出现的次数 // var names = ['Alice', 'Bob', 'Tiff', 'Bruce', 'Alice']; // var countedNames = ...
随机推荐
- 通过canvas合成图片
通过canvas合成图片 效果图 页面布局部分 两个图片以及一个canvas画布 <img src="https://qnlite.gtimg.com/qqnewslite/20190 ...
- nyoj 23-取石子(一)(博弈)
23-取石子(一) 内存限制:64MB 时间限制:3000ms Special Judge: No accepted:20 submit:33 题目描述: 一天,TT在寝室闲着无聊,和同寝的人玩起了取 ...
- source for "Android 28 platform" not found
source for "Android 28 platform" not found 解决办法:点击右上角的Download,但是下载完点击Refresh之后没有反应,这时候需要重 ...
- 程序员用于机器学习数据科学的3个顶级 Python 库
NumPy NumPy(数值 Python 的简称)是其中一个顶级数据科学库,它拥有许多有用的资源,从而帮助数据科学家把 Python 变成一个强大的科学分析和建模工具.NumPy 是在 BSD 许可 ...
- 使用原生javaScript绘制带图片的二维码---js
使用链接生成二维码主要是使用qr.js或者其他,把链接转化为二维码的形式,在使用canvas时需要设置画布的尺寸,生成的颜色. <div class="qr_code"> ...
- Scrapy中的反反爬、logging设置、Request参数及POST请求
常用的反反爬策略 通常防止爬虫被反主要有以下几策略: 动态设置User-Agent(随机切换User-Agent,模拟不同用户的浏览器信息.) 禁用cookies(也就是不启用cookies midd ...
- word2vec C源码解析
http://blog.csdn.net/google19890102/article/details/51887344
- SpringBoot 整合 Zookeeper 接入Starring微服务平台
背景 最近接的一个项目是基于公司产品Starring做的微服务支付平台,纯后台项目,实现三方支付公司和银行接口来完成用户账户扣款,整合成通用支付接口发布给前端调用. 但是扯蛋了,这边前端什么都不想做, ...
- 从spring源码汲取营养:模仿spring事件发布机制,解耦业务代码
前言 最近在项目中做了一项优化,对业务代码进行解耦.我们部门做的是警用系统,通俗的说,可理解为110报警.一条警情,会先后经过接警员.处警调度员.一线警员,警情是需要记录每一步的日志,是要可追溯的,比 ...
- 通过 Python 理解 Mixin 概念
Mixin 的概念 Mixin 即 Mix-in,常被译为"混入",是一种编程模式,在 Python 等面向对象语言中,通常它是实现了某种功能单元的类,用于被其他子类继承,将功能组 ...