数组去重,一般需求是给你一个数组,调用去重方法,返回数值副本,副本中没有重复元素。一般来说,两个元素通过 === 比较返回 true 的视为相同元素,需要去重,所以,1 和 "1" 是不同的元素,1 和 new Number(1) 是不同的元素,{} 和 {} 是不同的元素(引用不同)。(当然如果需求认为 {} 和 {} 算作相同的元素,那么解法就不一样了)

method 1
使用两重循环
function unique(arr) {
var res = [];
for(var i = 0, len = arr.length;i < len; i++) {
var item = arr[i];
for(var j = 0, jLen = res.length; j<jLen; j++) {
if(item == res[j]) break;
}
if(j == jLen) res.push(item);
}
return res;
}
method 2
function unique(arr) {
var ret = []
for (var i = 0; i < arr.length; i++) {
var item = arr[i]
if (ret.indexOf(item) === -1) {
ret.push(item)
}
}
return ret
}
这里判断可以使用一个语法糖
function unique(arr) {
var res = [];
for(var i = 0, len = arr.length;i < len; i++) {
var item = arr[i];
(res.indexOf(item) === -1) && res.push(item);
}
return res;
}
但是在低版本浏览器并没有 indexOf
var indexOf = [].indexOf ?
function(arr, item) {
return arr.indexOf(item)
} :
function indexOf(arr, item) {
for (var i = 0; i < arr.length; i++) {
if (arr[i] === item) {
return i
}
}
return -1
}
function unique(arr) {
var ret = []
for (var i = 0; i < arr.length; i++) {
var item = arr[i]
if (indexOf(ret, item) === -1) {
ret.push(item)
}
}
return ret
}
method3
使用两重循环的另外一种比较方式,前面是将原数组的元素和结果数组一一比较,下面我们可以将原数组的重复元素的最后一个元素放入数组中
function unique(arr) {
var ret = [];
var len = arr.length;
var isRepeat;
for(var i=0; i<len; i++) {
isRepeat = false;
for(var j=i+1; j<len; j++) {
if(arr[i] === arr[j]){
isRepeat = true;
break;
}
}
if(!isRepeat){
ret.push(arr[i]);
}
}
return ret;
}
这里还有一个优化的版本
function unique(a) {
var res = [];
for (var i = 0, len = a.length; i < len; i++) {
for (var j = i + 1; j < len; j++) {
// 这一步十分巧妙
// 如果发现相同元素
// 则 i 自增进入下一个循环比较
if (a[i] === a[j])
j = ++i; //j = i = i + 1;
}
res.push(a[i]);
}
return res;
}
method4
用 javascript 中的 object 对象来当作 哈希表
function dedup(arr) {
var hashTable = {};
return arr.filter(function(value,index,arr){
var key = JSON.stringify(value);
var match = Boolean(hashTable[key]);
return (match ? false : hashTable[key] = true);
});
}
因为 Object 的 key 值都是 String 类型,所以对于 1 和 "1" 无法分别,我们可以稍微改进下,将类型也存入 key 中
function dedup(arr) {
var ret = [];
var hash = {};
for(var i = 0; i < arr.length; i++) {
var item = arr[i];
var key = typeof(item) + item;
if(hash[key] !== 1) {
ret.push(item)
hash[key] = 1;
}
}
return ret;
}
总结
以上所述是小编给大家介绍的JavaScript数组去重的多种方法(四种),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# js
# 数组去重
# JavaScript数组去重的两种方法推荐
# JavaScript数组去重的五种方法
# js数组去重的5种算法实现
# javascript数组去重的六种方法汇总
# js数组去重的方法汇总
# JS数组去重与取重的示例代码
# 关于js数组去重的问题小结
# js数组去重的常用方法总结
# 两个数组去重的JS代码
# 我们可以
# 小编
# 将原
# 都是
# 给你
# 在此
# 给大家
# 还有一个
# 可以使用
# 四种
# 所述
# 给我留言
# 感谢大家
# 版本浏览器
# 组中
# 疑问请
# 有任何
# 样了
# 但是在
# 这一步
相关文章:
美食网站链接制作教程视频,哪个教做美食的网站比较专业点?
如何解决VPS建站LNMP环境配置常见问题?
如何快速搭建自助建站会员专属系统?
青岛网站设计制作公司,查询青岛招聘信息的网站有哪些?
如何在局域网内绑定自建网站域名?
如何处理“XML格式不正确”错误 常见XML well-formed问题解决方法
建站之星与建站宝盒如何选择最佳方案?
建站主机CVM配置优化、SEO策略与性能提升指南
魔毅自助建站系统:模板定制与SEO优化一键生成指南
西安制作网站公司有哪些,西安货运司机用的最多的app或者网站是什么?
如何在自有机房高效搭建专业网站?
焦点电影公司作品,电影焦点结局是什么?
如何在服务器上三步完成建站并提升流量?
建站之家VIP精选网站模板与SEO优化教程整合指南
香港服务器选型指南:免备案配置与高效建站方案解析
高防服务器租用指南:配置选择与快速部署攻略
高端建站三要素:定制模板、企业官网与响应式设计优化
建站之星ASP如何实现CMS高效搭建与安全管理?
建站之星如何助力网站排名飙升?揭秘高效技巧
建站主机助手选型指南:2025年热门推荐与高效部署技巧
英语简历制作免费网站推荐,如何将简历翻译成英文?
历史网站制作软件,华为如何找回被删除的网站?
建站之星伪静态规则如何设置?
建站之星手机一键生成:多端自适应+小程序开发快速建站指南
如何在阿里云ECS服务器部署织梦CMS网站?
无锡营销型网站制作公司,无锡网选车牌流程?
宝塔建站教程:一键部署配置流程与SEO优化实战指南
在线教育网站制作平台,山西立德教育官网?
南平网站制作公司,2025年南平市事业单位报名时间?
c# await 一个已经完成的Task会发生什么
如何在建站之星网店版论坛获取技术支持?
如何做网站制作流程,*游戏网站怎么搭建?
javascript中的try catch异常捕获机制用法分析
如何快速生成凡客建站的专业级图册?
建站主机类型有哪些?如何正确选型
建站主机空间推荐 高性价比配置与快速部署方案解析
如何在IIS中新建站点并配置端口与IP地址?
巅云智能建站系统:可视化拖拽+多端适配+免费模板一键生成
如何快速搭建高效香港服务器网站?
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?
宝盒自助建站智能生成技巧:SEO优化与关键词设置指南
哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?
建站之星客服服务时间及联系方式如何?
如何用5美元大硬盘VPS安全高效搭建个人网站?
制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?
上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?
平台云上自主建站:模板化设计与智能工具打造高效网站
如何通过NAT技术实现内网高效建站?
网站制作网站,深圳做网站哪家比较好?
*请认真填写需求信息,我们会在24小时内与您取得联系。