配列の重複排除の一般的な要件は、配列を指定し、重複排除メソッドを呼び出し、値のコピーを返すことです。コピーには重複する要素はありません。一般に、=== 比較によって true を返す 2 つの要素は同じ要素とみなされ、重複を排除する必要があります。したがって、1 と "1" は異なる要素であり、1 と new Number(1) は異なる要素です。 } と {} は異なる要素 (異なる参照) です。 (もちろん、{} と {} を同じ要素としてカウントするという要件がある場合、解決策は異なります) この記事では主に、JavaScript 配列の重複を排除するためのいくつかの方法を説明します。
方法1
二重ループを使用する
function unique(arr) { var res = []; for(var i = 0, len = arr.length;i < len; i++) { var item = arr[i]; for(var j = 0, jLen = res.length; j<jLen; j++) { if(item == res[j]) break; } if(j == jLen) res.push(item); } return res; }
方法2
function unique(arr) { var ret = [] for (var i = 0; i < arr.length; i++) { var item = arr[i] if (ret.indexOf(item) === -1) { ret.push(item) } } return ret }
シュガー構文を使用できます
function unique(arr) { var res = []; for(var i = 0, len = arr.length;i < len; i++) { var item = arr[i]; (res.indexOf(item) === -1) && res.push(item); } return res; }
しかし、以前のバージョンのブラウザにはindexOfがありません
var indexOf = [].indexOf ? function(arr, item) { return arr.indexOf(item) } : function indexOf(arr, item) { for (var i = 0; i < arr.length; i++) { if (arr[i] === item) { return i } } return -1 } function unique(arr) { var ret = [] for (var i = 0; i < arr.length; i++) { var item = arr[i] if (indexOf(ret, item) === -1) { ret.push(item) } } return ret }
方法3
二重ループAのもう一方を使用します前の比較方法は、元の配列と結果の配列の要素を 1 つずつ比較するものです。次に、元の配列の繰り返し要素の最後の要素を配列に入れることができます
function unique(arr) { var ret = []; var len = arr.length; var isRepeat; for(var i=0; i<len; i++) { isRepeat = false; for(var j=i+1; j<len; j++) { if(arr[i] === arr[j]){ isRepeat = true; break; } } if(!isRepeat){ ret.push(arr[i]); } } return ret; }
version
function unique(a) { var res = []; for (var i = 0, len = a.length; i < len; i++) { for (var j = i + 1; j < len; j++) { // 这一步十分巧妙 // 如果发现相同元素 // 则 i 自增进入下一个循环比较 if (a[i] === a[j]) j = ++i; //j = i = i + 1; } res.push(a[i]); } return res; }
method4
JavaScriptのオブジェクトオブジェクトをハッシュテーブルとして使用します
function dedup(arr) { var hashTable = {}; return arr.filter(function(value,index,arr){ var key = JSON.stringify(value); var match = Boolean(hashTable[key]); return (match ? false : hashTable[key] = true); }); }
Objectのキー値は全てString型なので1と「1」の区別がつきません。改良して型をキーに保存する
function dedup(arr) { var ret = []; var hash = {}; for(var i = 0; i < arr.length; i++) { var item = arr[i]; var key = typeof(item) + item; if(hash[key] !== 1) { ret.push(item) hash[key] = 1; } } return ret; }
関連する推奨事項:
配列の重複排除と並べ替え操作の jQuery の簡単な実装詳しい説明
以上がJavaScript 配列から重複を削除するいくつかのメソッドを共有するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。