JavaScript中数组去除重复
2016-04-11 21:38
639 查看
方式一:常规模式
1.构建一个新的临时数组存放结果
2.for循环中每次从原数组中取出一个元素,用这个元素循环与临时数组对比
3.若临时数组中没有该元素,则存到临时数组中
方式二:使用了默认Js数组sort默认排序,是按ASCII进行排序;
若要按照升降序的排列如下:<控制台打印输出>
![](https://oscdn.geek-share.com/Uploads/Images/Content/202003/21/14184c181ef7838c21d83706717c9f1f.png)
1.先将当前数组进行排序
2.检查当前中的第i个元素 与 临时数组中的最后一个元素是否相同,因为已经排序,所以重复元素会在相邻位置
3.如果不相同,则将该元素存入结果数组中
方式三:<推荐>利用json对象是否有属性值
1.创建一个新的数组存放结果
2.创建一个空对象json
3.for循环时,每次取出一个元素与对象进行对比,如果这个元素不重复,则把它存放到结果数组中,同时把这个元素的内容作为对象的一个属性,并赋值为1,存入到第2步建立的对象中。
说明:至于如何对比,就是每次从原数组中取出一个元素,然后到对象中去访问这个属性,如果能访问到值,则说明重复。
1.构建一个新的临时数组存放结果
2.for循环中每次从原数组中取出一个元素,用这个元素循环与临时数组对比
3.若临时数组中没有该元素,则存到临时数组中
//方式一: Array.prototype.unique = function(){ var newArr=[this[0]]; //数组结果 for(var i = 0, len = this.length; i < len; i++){ var repeat=false; //设置重复参数 for(var j = 0, len2 = newArr.length; j < len2; j++){ if (this[i]==newArr[j]) { repeat=true; //若重复设置为true break; } } //去重push数组 if (!repeat) { newArr.push(this[i]); } } return newArr; }; var arr=[1,4,7,98,8,6,9,7,1,98]; console.info(arr.unique(arr));
方式二:使用了默认Js数组sort默认排序,是按ASCII进行排序;
若要按照升降序的排列如下:<控制台打印输出>
![](https://oscdn.geek-share.com/Uploads/Images/Content/202003/21/14184c181ef7838c21d83706717c9f1f.png)
1.先将当前数组进行排序
2.检查当前中的第i个元素 与 临时数组中的最后一个元素是否相同,因为已经排序,所以重复元素会在相邻位置
3.如果不相同,则将该元素存入结果数组中
//方式二 Array.prototype.unique2 = function(argument){ this.sort(); //排序ASCII码 var newArr=[this[0]]; for(var i = 0, len2 = this.length; i < len2; i++){ if (this[i]!==newArr[newArr.length-1]) { newArr.push(this[i]); } } return newArr; }; var array2=['b','b','v','n']; console.info(array2.unique2());
方式三:<推荐>利用json对象是否有属性值
1.创建一个新的数组存放结果
2.创建一个空对象json
3.for循环时,每次取出一个元素与对象进行对比,如果这个元素不重复,则把它存放到结果数组中,同时把这个元素的内容作为对象的一个属性,并赋值为1,存入到第2步建立的对象中。
说明:至于如何对比,就是每次从原数组中取出一个元素,然后到对象中去访问这个属性,如果能访问到值,则说明重复。
//方式三 Array.prototype.unique3=function(){ var res=[]; //创建一个存放数组结果集 var json={};//对象属性标识数组中是否有重复元素 for(var i = 0, len = this.length; i < len; i++){ if (!json[this[i]]) { res.push(this[i]); json[this[i]]=1; } } return res; } var array3=['d','c','d','a','v','n','v']; console.info(array3.unique3());
相关文章推荐
- JS实现div块的拖放,调换位置
- fastjson生成和解析json数据
- js练习题三:使div变色 密码提示框
- 浅谈javascript的this指向
- JavaScript中数组和字符串的方法以及互相转换
- Javascript的9张思维导图学习
- Javascript的9张思维导图学习
- 关于火狐和IE下href="javascript:void(0)"兼容性的问题
- Effective JavaScript Item 35 使用闭包来保存私有数据
- Python实现Json结构对比的小工具兼谈编程求解问题
- 浏览器加载和渲染html的顺序(html/css/js)
- 浏览器加载和渲染html的顺序(html/css/js)
- jsp页面中的$(param.xxxxx)
- JS中把函数作为另一函数的参数传递总结
- JavaScript 项目实战工具类
- JS 基础回顾(一)
- js练习题二:函数接收
- [BZOJ2257][Jsoi2009]瓶子和燃料
- 关于JS出现的Cannot read property 'XXX' of null错误
- qt+evaluatejavascript