首页 > 编程 > JavaScript > 正文

详解JavaScript数组和字符串中去除重复值的方法

2019-11-20 10:26:11
字体:
来源:转载
供稿:网友

原理在代码中表现得非常清晰,我们直接来看代码例子:

var ages = array.map(function(obj) { return obj.age; }); ages = ages.filter(function(v,i) { return ages.indexOf(v) == i; });  console.log(ages); //=> [17, 35] 
function isBigEnough(element) {  return element >= 10; } var filtered = [12, 5, 8, 130, 44].filter(isBigEnough); // filtered is [12, 130, 44] 
function onlyUnique(value, index, self) {    return self.indexOf(value) === index; }  // usage example: var a = ['a', 1, 'a', 2, '1']; var unique = a.filter( onlyUnique ); // returns ['a', 1, 2, '1'] 

比较好使的Function(不兼容IE7)

function unique(array){   return array.filter(function(el, index, arr) {     return index == arr.indexOf(el);   }); } 

 
比较好使的Function(兼容IE7)

//去除数组中重复值 function getNoRepeat(s) {   return s.sort().join(",,").replace(/(,|^)([^,]+)(,,/2)+(,|$)/g,"$1$2$4").replace(/,,+/g,",").replace(/,$/,"").split(","); }  var arr = ["北京", "上海", "天津", "武汉", "上海", "天津", "武汉", "北京", "上海", "天津", "武汉", "天津", "武汉", "天津", "武汉", "天津", "武汉", "北京", "上海", "天津", "武汉", "上海", "天津", "武汉", "北京", "上海", "天津", "武汉", "天津", "武汉", "天津", "武汉", "天津", "武汉", "北京", "上海", "天津", "武汉", "上海", "天津", "武汉", "北京", "上海", "天津", "武汉", "天津", "武汉", "天津", "武汉", "天津", "武汉"]; arr = getNoRepeat(arr);  alert(arr.length);// 4 alert(arr.toString()); // "北京", "上海", "天津", "武汉" 

利用map原理

var arr = ["北京", "上海", "天津", "武汉", "上海", "天津", "武汉", "北京", "上海", "天津", "武汉", "天津", "武汉", "天津", "武汉", "天津", "武汉", "北京", "上海", "天津", "武汉", "上海", "天津", "武汉", "北京", "上海", "天津", "武汉", "天津", "武汉", "天津", "武汉", "天津", "武汉", "北京", "上海", "天津", "武汉", "上海", "天津", "武汉", "北京", "上海", "天津", "武汉", "天津", "武汉", "天津", "武汉", "天津", "武汉"];  var json = {}; for(var i = 0; i < arr.length; i++){   json[arr[i]] = arr[i]; }  arr = new Array(); for(var key in json){   arr.push(key); } alert(arr.toString()); // "北京", "上海", "天津", "武汉" 

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表