Javascript
 Computer >> コンピューター >  >> プログラミング >> Javascript

JavaScriptの配列の配列で共通の配列を除外する方法


このような配列の配列があるとします-

const arr = [
   [
      "Serta",
      "Black Friday"
   ],
   [
      "Serta",
      "Black Friday"
   ],
   [
      "Simmons",
      "Black Friday"
   ],
   [
      "Simmons",
      "Black Friday"
   ],
   [
      "Simmons",
      "Black Friday"
   ],
   [
      "Simmons",
      "Black Friday"
   ]
];

そのような配列を1つ取り込むJavaScript関数を作成する必要があります。また、関数は、元の配列からのすべての一意のサブ配列を含む新しい配列を返す必要があります。

このためのコードは-

になります
const arr = [
   [
      "Serta",
      "Black Friday"
   ],
   [
      "Serta",
      "Black Friday"
   ],
   [
      "Simmons",
      "Black Friday"
   ],
   [
      "Simmons",
      "Black Friday"
   ],
   [
      "Simmons",
      "Black Friday"
   ],
   [
      "Simmons",
      "Black Friday"
   ]
];
const filterCommon = arr => {
   const map = Object.create(null);
   let res = [];
   res = arr.filter(el => {
      const str = JSON.stringify(el);
      const bool = !map[str];
      map[str] = true;
      return bool;
   });
   return res;
};
console.log(filterCommon(arr));

出力

コンソールの出力-

[ [ 'Serta', 'Black Friday' ], [ 'Simmons', 'Black Friday' ] ]

  1. JavaScriptで配列を減らす方法は?

    以下は、JavaScriptで配列を減らすためのコードです- 例 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document</title> <style>   &n

  2. JavaScriptでオブジェクトを含む配列の配列をループするにはどうすればよいですか?

    以下は、JavaScriptのオブジェクトを含む配列の配列をループするコードです- 例 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document</title> <style>