js 巧妙去除数组中的重复项


Posted in Javascript onJanuary 25, 2010

时不时的看下YUI的源码, 总会有些收获.

一. YUI中的源码'

var toObject = function(a) { 
var o = {}; 
for (var i=0, j=a.length; i<j; i=i+1) { // 这里我调整了下, YUI源码中是i<a.length 
o[a[i]] = true; 
} 
return o; 
}; 
var keys = function(o) { 
var a=[], i; 
for (i in o) { 
if (o.hasOwnProperty(i)) { // 这里, YUI源码中是lang.hasOwnProperty(o, i) 
a.push(i); 
} 
} 
return a; 
}; 
var uniq = function(a) { 
return keys(toObject(a)); 
};

注:为了书写方便, 我省略了各方法前的类名, 大伙可自行查阅YUI的源码, 2.7.0b与2.8.0r4均可(此部分的代码是一样的).

二. 该方法的思路
1. 先以目标数组的值为key生成一个对象. 这一步是最核心的: 因为在一个对象中, key是无法重复的, 这样就很巧妙的排除了重复值;

2. 遍历生成的对象, 将这些key取出来放到一个数组中, OK, 到此就大功告成了!(简单吧, 只需两步就行)

三. 该方法的特点
1. 对于该方法, 不论数组有多少项, 都只会遍历两次, 在性能上的优势较明显(想想自己以前的做法: 对数组项进行逐个对比, 其性能之差, 可想而知).

2. 经我的测试, 该方法只适用于数组项为字符串, 数字的一维数组(我觉得, 对多维数组进行排除重复项的操作, 实在是太杯具了!).

其它的方法可以参考上一篇文章。

Javascript 相关文章推荐
IE浏览器PNG图片透明效果代码
Sep 02 Javascript
jquery设置元素的readonly和disabled的写法
Sep 22 Javascript
Jquery检验手机号是否符合规则并根据手机号检测结果将提交按钮设为不同状态
Nov 26 Javascript
js实现跨域访问的三种方法
Dec 09 Javascript
浏览器兼容的JS写法总结
Apr 27 Javascript
jQuery元素属性操作实例(设置、获取及删除元素属性)
Sep 08 Javascript
Easyui和zTree两种方式分别实现树形下拉框
Aug 04 Javascript
小白教程|一小时上手最流行的前端框架vue(推荐)
Apr 10 Javascript
layui2.0使用table+laypage实现真分页
Jul 27 Javascript
微信小程序加载机制及运行机制图解
Nov 27 Javascript
extjs图表绘制之条形图实现方法分析
Mar 06 Javascript
vue props 一次传多个值实例
Jul 22 Javascript
将函数的实际参数转换成数组的方法
Jan 25 #Javascript
javascript中利用数组实现的循环队列代码
Jan 24 #Javascript
document.getElementById为空或不是对象的解决方法
Jan 24 #Javascript
JavaScript 未结束的字符串常量常见解决方法
Jan 24 #Javascript
php gethostbyname获取域名ip地址函数详解
Jan 24 #Javascript
setTimeout与setInterval在不同浏览器下的差异
Jan 24 #Javascript
js 模拟实现类似c#下的hashtable的简单功能代码
Jan 24 #Javascript
You might like
thinkPHP引入类的方法详解
2016/12/08 PHP
thinkphp5 框架结合plupload实现图片批量上传功能示例
2020/04/04 PHP
Thinkphp极验滑动验证码实现步骤解析
2020/11/24 PHP
extjs fckeditor集成代码
2009/05/10 Javascript
javascript模拟select,jselect的方法实现
2012/11/08 Javascript
jQuery动态地获取系统时间实现代码
2013/05/24 Javascript
JavaScript中为什么null==0为false而null大于=0为true(个人研究)
2013/09/16 Javascript
js控制页面控件隐藏显示的两种方法介绍
2013/10/09 Javascript
js通过八个点 拖动改变div大小的实现方法
2014/03/05 Javascript
jQuery中deferred对象使用方法详解
2016/07/14 Javascript
Vue.js 父子组件通讯开发实例
2016/09/06 Javascript
javascript 封装Date日期类实例详解
2017/05/28 Javascript
setTimeout时间设置为0详细解析
2018/03/13 Javascript
详解性能更优越的小程序图片懒加载方式
2018/07/18 Javascript
Nodejs中的JWT和Session的使用
2018/08/21 NodeJs
微信小程序实现签到功能
2018/10/31 Javascript
layui数据表格实现重载数据表格功能(搜索功能)
2019/07/27 Javascript
Vue 自定义指令实现一键 Copy功能
2019/09/16 Javascript
vue 将多个过滤器封装到一个文件中的代码详解
2020/09/05 Javascript
python使用scrapy解析js示例
2014/01/23 Python
Python代码调试的几种方法总结
2015/04/15 Python
Python模拟登陆实现代码
2017/06/14 Python
Python爬豆瓣电影实例
2018/02/23 Python
用python处理MS Word的实例讲解
2018/05/08 Python
Python 图像处理: 生成二维高斯分布蒙版的实例
2019/07/04 Python
Python爬虫 批量爬取下载抖音视频代码实例
2019/08/16 Python
教师试用期自我鉴定
2014/02/12 职场文书
暑期培训班招生方案
2014/08/26 职场文书
纪念九一八事变演讲稿:青少年应树立远大理想
2014/09/14 职场文书
项目建议书
2015/02/04 职场文书
工作能力自我评价2015
2015/03/05 职场文书
运动会宣传稿50字
2015/07/23 职场文书
如何书写读后感?(附范文)
2019/07/26 职场文书
普希金的诗歌赏析(3首)
2019/08/20 职场文书
Java实现多文件上传功能
2021/06/30 Java/Android
JavaScript实现九宫格拖拽效果
2022/06/28 Javascript