ホームページ >ウェブフロントエンド >jsチュートリアル >JavaScript 配列から重複を削除するいくつかのメソッドを共有する

JavaScript 配列から重複を削除するいくつかのメソッドを共有する

小云云
小云云オリジナル
2018-02-08 11:40:591652ブラウズ

配列の重複排除の一般的な要件は、配列を指定し、重複排除メソッドを呼び出し、値のコピーを返すことです。コピーには重複する要素はありません。一般に、=== 比較によって 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;
}

関連する推奨事項:

配列の重複排除を実装するための PHP メソッドのコード

配列の重複排除を実装する簡単なメソッドの JS 分析

配列の重複排除と並べ替え操作の jQuery の簡単な実装詳しい説明

以上がJavaScript 配列から重複を削除するいくつかのメソッドを共有するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。