数组去重,一般需求是给你一个数组,调用去重方法,返回数值副本,副本中没有重复元素。一般来说,两个元素通过 === 比较返回 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代码
# 我们可以
# 小编
# 将原
# 都是
# 给你
# 在此
# 给大家
# 还有一个
# 可以使用
# 四种
# 所述
# 给我留言
# 感谢大家
# 版本浏览器
# 组中
# 疑问请
# 有任何
# 样了
# 但是在
# 这一步
相关文章:
番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
制作企业网站建设方案,怎样建设一个公司网站?
定制建站是什么?如何实现个性化需求?
完全自定义免费建站平台:主题模板在线生成一站式服务
开封网站制作公司,网络用语开封是什么意思?
如何基于PHP生成高效IDC网络公司建站源码?
如何在云主机上快速搭建网站?
制作网站外包平台,自动化接单网站有哪些?
武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?
ppt制作免费网站有哪些,ppt模板免费下载网站?
GML (Geography Markup Language)是什么,它如何用XML来表示地理空间信息?
较简单的网站制作软件有哪些,手机版网页制作用什么软件?
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南
如何通过建站之星自助学习解决操作问题?
在线流程图制作网站手机版,谁能推荐几个好的CG原画资源网站么?
公司网站制作费用多少,为公司建立一个网站需要哪些费用?
MySQL查询结果复制到新表的方法(更新、插入)
外汇网站制作流程,如何在工商银行网站上做外汇买卖?
高端企业智能建站程序:SEO优化与响应式模板定制开发
东莞市网站制作公司有哪些,东莞找工作用什么网站好?
官网自助建站平台指南:在线制作、快速建站与模板选择全解析
怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?
如何通过wdcp面板快速创建网站?
娃派WAP自助建站:免费模板+移动优化,快速打造专业网站
西安专业网站制作公司有哪些,陕西省建行官方网站?
成都品牌网站制作公司,成都营业执照年报网上怎么办理?
如何优化Golang Web性能_Golang HTTP服务器性能提升方法
齐河建站公司:营销型网站建设与SEO优化双核驱动策略
制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?
定制建站平台哪家好?企业官网搭建与快速建站方案推荐
企业微网站怎么做,公司网站和公众号有什么区别?
Python多线程使用规范_线程安全解析【教程】
微信h5制作网站有哪些,免费微信H5页面制作工具?
网站图片在线制作软件,怎么在图片上做链接?
香港服务器建站指南:免备案优势与SEO优化技巧全解析
魔方云NAT建站如何实现端口转发?
c# 在高并发场景下,委托和接口调用的性能对比
怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?
如何彻底删除建站之星生成的Banner?
焦点电影公司作品,电影焦点结局是什么?
唐山网站制作公司有哪些,唐山找工作哪个网站最靠谱?
非常酷的网站设计制作软件,酷培ai教育官方网站?
网站制作员失业,怎样查看自己网站的注册者?
海南网站制作公司有哪些,海口网是哪家的?
利用JavaScript实现拖拽改变元素大小
建站之星ASP如何实现CMS高效搭建与安全管理?
公司网站设计制作厂家,怎么创建自己的一个网站?
宝塔新建站点报错如何解决?
*请认真填写需求信息,我们会在24小时内与您取得联系。