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

JavaScriptで配列をフラット化します。


ネストされた配列を受け取り、ネストせずに配列に存在するすべての要素を含む配列を返すJavaScript配列関数を作成する必要があります。

例-

//if the input is:
const arr = [[1, 2, 3], [4, 5], [6]];
//then the output should be:
const output = [1, 2, 3, 4, 5, 6];

したがって、この関数のコードを書いてみましょう-

方法1:再帰を使用する

ここでは、元のネストされた配列をループし、ネストされた要素要素を新しい配列に再帰的にプッシュします。

const arr = [[1, 2, 3], [4, 5], [6]];
const flatten = function(){
   let res = [];
   for(let i = 0; i < this.length; i++){
      if(Array.isArray(this[i])){
         res.push(...this[i].flatten());
      } else {
         res.push(this[i]);
      };
   };
   return res;
};
Array.prototype.flatten = flatten;
console.log(arr.flatten());

方法2:Arrray.prototype.reduce()を使用する

ここでは、reduce()メソッドを使用して、次のような新しい配列を作成します-

const arr = [[1, 2, 3], [4, 5], [6]];
const flatten = function(){
   return this.reduce((acc, val) => {
      return acc.concat(...val);
   }, []);
};
Array.prototype.flatten = flatten;
console.log(arr.flatten());

出力

両方の方法のコンソール出力は-

になります
[ 1, 2, 3, 4, 5, 6 ]

  1. JavaScriptの配列reverse()

    JavaScript配列reverse()関数は、配列内の要素の順序を逆にします 以下は、配列のreverse()関数のコードです- 例 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document&

  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> <