版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/longzhoufeng/article/details/78840974 </div>
<link rel="stylesheet" href="https://csdnimg.cn/release/phoenix/template/css/ck_htmledit_views-f57960eb32.css">
<div id="content_views" class="markdown_views">
<!-- flowchart 箭头图标 勿删 -->
<svg xmlns="http://www.w3.org/2000/svg" style="display: none;"><path stroke-linecap="round" d="M5,0 0,2.5 5,5z" id="raphael-marker-block" style="-webkit-tap-highlight-color: rgba(0, 0, 0, 0);"></path></svg>
<h3 id="第一种方法但是下面的这种方法数字字符串类似相同返回的还是真有点不靠谱如果是其它的字符是可以的"><a name="t0"></a>第一种方法:但是下面的这种方法数字字符串类似相同,返回的还是真,有点不靠谱,如果是其它的字符是可以的</h3>
var ary11 = new Array("1", "ff", "11", "aa", "2222");
function mm(a) {
return /(x0f[^x0f]+)x0f[sS]*1/.test("x0f" + a.join("x0fx0f") + "x0f");
}
mm(ary11)
alert(mm(ary11))
第二种方法:但是下面的这种方法数字字符串类似相同,返回的也还是真,有点不靠谱,如果是其它的字符是可以的
var ary = ["1", "ff", "11", "aa", "2222"]
var s = ary.join(",") + ",";
for(var i = 0; i < ary.length; i++) {
if(s.replace(ary[i] + ",", "").indexOf(ary[i] + ",") > -1) {
alert("数组中有重复元素:" + ary[i]);
break;
}
}
第三种方法:这种方法好像不会有什么问题
var ary = new Array("11", "222", "33", "111", "22");
var nary = ary.sort();
for(var i = 0; i < nary.length - 1; i++) {
if(nary[i] == nary[i + 1]) {
alert("重复内容:" + nary[i]);
}
}
第四种方法:这种方法应该不会有什么问题,这个使用了map类似的功能,没毛病,我用的就是这个
var ary = new Array("1111", "222", "33", "111", "22");
alert(isRepeat(ary));
function isRepeat(arr) {
var hash = {};
for(var i in arr) {
if(hash[arr[i]]) {
return true;
}
hash[arr[i]] = true;
}
return false;
}
<link href="https://csdnimg.cn/release/phoenix/mdeditor/markdown_views-258a4616f7.css" rel="stylesheet">
</div>