>  기사  >  웹 프론트엔드  >  javascript_javascript 기술에서 배열의 요소가 반복되는지 확인하는 방법에 대한 방법 모음

javascript_javascript 기술에서 배열의 요소가 반복되는지 확인하는 방법에 대한 방법 모음

WBOY
WBOY원래의
2016-05-16 19:19:191130검색

var str = new Array();  
比如有这么一组数组,里面放了20个18位的身份证号码  
要判断里面的身份证号码是否有重复  
如何快速判断?

复制代码 代码如下:

var ary = new Array("111","22","33","111");
    var s = ary.join(",")+",";
    for(var i=0;i {
if(s.replace(ary[i]+",","").indexOf(ary[i]+",")>-1)
 {
   alert("有重复!");
 }
}
 

复制代码 代码如下:

var ary = new Array("111","22","33","111");
var nary=ary.sort();
for(var i=0;i   {if (nary[i]==nary[i+1])
       {alert("重复内容:"+nary[i]);}
    }

活用正则表达式里的 \1 (第一个匹配结果)
先用 join() 把数组转换成字符串且夹塞指定的分隔符 \x0f(这种分隔符用户一般是输不进来的),这一步纯粹是为简化且精确脚本而做。
这种模式是我写 MzTreeView 的时候想出来的招数,可以跳过 for 循环达到极端的效率。
复制代码 代码如下:

var hash = {};
for(var i in arr) {
  if(hash[arr[i]])
    return true;
  hash[arr[i]] = true;
}
return false;


[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.