[英]Find common elements in 1 array using Javascript
我有這個:
var mergeUniqueItems = ["-JsDEcxz_ZSGFLKwd1QM",
"-JsJ2NXGDYKI6QRsuXVK",
"-JsJ2RK-kOG2eGcG04xF",
"-JsJ2RK-kOG2eGcG04xF",
"-JsJ2YLPiP6751zh8geS"]
我用了這個:
var duplicateArray = [];
for (var i = 0; i < mergeUniqueItems.length; i ++){
for (var j = 1; j < mergeUniqueItems.length; j ++){
if (mergeUniqueItems[i] == mergeUniqueItems[j]){
duplicateArray.push(mergeUniqueItems[i]);
}
}
}
console.log(duplicateArray);
結果變成這樣:
["-JsJ2NXGDYKI6QRsuXVK",
"-JsJ2RK-kOG2eGcG04xF",
"-JsJ2RK-kOG2eGcG04xF",
"-JsJ2RK-kOG2eGcG04xF",
"-JsJ2RK-kOG2eGcG04xF",
"-JsJ2YLPiP6751zh8geS"]
當我的期望是在1個數組中重復項時,如下所示:
["-JsJ2RK-kOG2eGcG04xF"]
如果有多個重復值,則數組應如下所示:
["-JsJ2RK-kOG2eGcG04xF", "another_duplicate_1", "another_duplicate_2", ...]
我真的不知道我的代碼有什么問題,請幫忙。
謝謝
從i+1
而不是1
開始j
,並檢查以確保尚未添加重復值。
for (var i = 0; i < mergeUniqueItems.length; i ++){
for (var j = i + 1; j < mergeUniqueItems.length; j ++){
if (mergeUniqueItems[i] == mergeUniqueItems[j]){
if (duplicateArray.indexOf(mergeUniqueItems[i]) < 0)
duplicateArray.push(mergeUniqueItems[i]);
break;
}
這是Pointy正確答案的替代方法。
var duplicateArray = mergeUniqueItems.filter(function(item, i, orig) {
return orig.indexOf(item, i+1) === -1;
});
console.log(duplicateArray);
比使用顯式循環好一點。
請注意,它將保留最后一個而不是第一個重復項。 如果存在問題,請改用.indexOf(item, i-1)
。
我可能對您的需求感到困惑。 如果您只需要每個重復項的單個實例,則將是這樣的:
var duplicateArray = mergeUniqueItems.filter(function(item, i, orig) {
var nxt = orig.indexOf(item, i+1);
return nxt !== -1 && orig.lastIndexOf(item) == nxt;
});
或這個:
var duplicateArray = mergeUniqueItems.filter(function(item, i, orig) {
var nxt = orig.indexOf(item, i+1);
return nxt !== -1 && orig.indexOf(item, nxt+1) === -1;
});
另一種方法是在第一個結果上使用單獨的.filter()
:
var duplicateArray = mergeUniqueItems.filter(function(item, i, orig) {
return orig.indexOf(item, i+1) !== -1;
}).filter(function(item, i, orig) {
return orig.indexOf(item, i+1) === -1;
});
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.