ホームページ > ウェブフロントエンド > jsチュートリアル > JavaScript で配列から重複要素を削除する方法のアイデアとコード例の詳細な説明

JavaScript で配列から重複要素を削除する方法のアイデアとコード例の詳細な説明

伊谢尔伦
リリース: 2017-07-24 13:27:33
オリジナル
1732 人が閲覧しました

プログラムを作成する過程で、配列から重複した要素を削除する必要に遭遇することがよくあります。 小さな配列の場合、二重ループを使用してこれを実現できます。 しかし、配列が比較的大きい場合、その中には数万の要素が含まれます。そうなると二重循環を使うことは非常に非効率になります。 ここで、js の機能を使用して、配列から重複要素を削除する効率的なメソッドを作成します。

<script> 
function unique(data){ 
data = data || []; 
var a = {}; 
for (var i=0; i<data.length; i++) { 
var v = data[i]; 
if (typeof(a[v]) == &#39;undefined&#39;){ 
a[v] = 1; 
} 
}; 
data.length=0; 
for (var i in a){ 
data[data.length] = i; 
} 
return data; 
} 
function test(){ 
var arr = [9,1,3,8,7,7,6,6,5,7,8,8,7,4,3,1]; 
var arr1 = unique(arr); 
alert(arr1.join(",")); 
} 
test(); 
</script>
ログイン後にコピー

出力結果:
9,1,3,8,7,6,5,4
JS配列の重複排除は、配列内の重複要素を削除することです:

Array.prototype.delRepeat=function(){ 
var newArray=new Array(); 
var len=this.length; 
for (var i=0;i<len ;i++){ 
for(var j=i+1;j<len;j++){ 
if(this[i]===this[j]){ 
j=++i; 
} 
} 
newArray.push(this[i]); 
} 
return newArray; 
}
ログイン後にコピー

しかし、明らかにここにforループが埋め込まれています別のfor大量のデータを処理する場合、ループは非常に時間がかかるはずです。非効率です! 検索と専門家のアドバイスを経て、新しいメソッドが最適化されました:

Array.prototype.delRepeat=function(){ 
var newArray=[]; 
var provisionalTable = {}; 
for (var i = 0, item; (item= this[i]) != null; i++) { 
if (!provisionalTable[item]) { 
newArray.push(item); 
provisionalTable[item] = true; 
} 
} 
return newArray; 
}
ログイン後にコピー

は一時的な ProvisioningTable オブジェクトを使用し、配列の値をキーとして使用します。 ProvisionTable オブジェクトの値に対応する値が存在しない場合、この配列の値を新しい配列にプッシュします。

以上がJavaScript で配列から重複要素を削除する方法のアイデアとコード例の詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート