var str = new Array(); 比如有这么一组数组,里面放了20个18位的身份证号码 要判断里面的身份证号码是否有重复 如何快速判断? 代码如下: var ary = new Array("111","22","33","111"); var s = ary.join(",")+","; for(var i=0;i<ary.length;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<nary.length-1;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;