配列からサブ配列を取得する方法は?


回答:


408

を見てみましょう Array.slice(begin, end)

const ar  = [1, 2, 3, 4, 5];

// slice from 1..3 - add 1 as the end index is not included

const ar2 = ar.slice(1, 3 + 1);

console.log(ar2);


22
オリジナルarは変更されていないことをここで明示的に言及する価値があるでしょう。 console.log(ar); // -> [1, 2, 3, 4, 5]
daemonexmachina 2018

17

を簡単に使用するにはslice、配列クラスの拡張機能を使用します。

Array.prototype.subarray = function(start, end) {
    if (!end) { end = -1; } 
    return this.slice(start, this.length + 1 - (end * -1));
};

次に:

var bigArr = ["a", "b", "c", "fd", "ze"];

Test1

bigArr.subarray(1, -1);

<["b"、 "c"、 "fd"、 "ze"]

Test2:

bigArr.subarray(2, -2);

<["c"、 "fd"]

Test3:

bigArr.subarray(2);

<["c"、 "fd"、 "ze"]

別の言語(Groovyなど)の開発者にとっては、より簡単かもしれません。



K_7の発言; 特に、ビルトイン(オブジェクト、配列、プロミスなど)へのモンキーパッチ適用は非常にいたずらです。提案されたネイティブへの名前変更強制するMooToolsの有名な例を参照してください。Array.prototype.containsArray.prototype.includes
daemonexmachina

言うまでもなく、このsubarrayメソッドは予期しない結果をもたらします。期待どおりのをbigArr.slice(1,-1)返します['b','c','fd'](-1は新しい配列の末尾から1つの要素を削除します)。しかしbigArr.subarray(1,-1)、と同じ結果を返します。bigArr.subarray(1)つまり、位置1からの終わりまですべてを言いますbigArr。また、ユーザーに常に負の数をendパラメーターとして指定することを強制しています。Any end >= -1はwhenと同じ結果になりend === undefinedます。一方、bigArr.slice(1,3)は返されますが['b','c']、これも期待されています。
daemonexmachina

5

const array_one = [11, 22, 33, 44, 55];
const start = 1;
const end = array_one.length - 1;
const array_2 = array_one.slice(start, end);
console.log(array_2);


ここでは修正をコンパイルしません。vararray_one = [11、22、33、44,55]; var ar2 = array_one.slice(0、array_one.length-1); console.log(ar2)
ボーマット

0

質問は、実際のために求めている新しい配列私はよりよい解決策を組み合わせることであろうと考えているので、Abdennour TOUMIの答えをクローン機能付:

function clone(obj) {
  if (null == obj || "object" != typeof obj) return obj;
  const copy = obj.constructor();
  for (const attr in obj) {
    if (obj.hasOwnProperty(attr)) copy[attr] = obj[attr];
  }
  return copy;
}

// With the `clone()` function, you can now do the following:

Array.prototype.subarray = function(start, end) {
  if (!end) {
    end = this.length;
  } 
  const newArray = clone(this);
  return newArray.slice(start, end);
};

// Without a copy you will lose your original array.

// **Example:**

const array = [1, 2, 3, 4, 5];
console.log(array.subarray(2)); // print the subarray [3, 4, 5, subarray: function]

console.log(array); // print the original array [1, 2, 3, 4, 5, subarray: function]

[ http://stackoverflow.com/questions/728360/most-elegant-way-to-clone-a-javascript-object]


9
スライスが元の配列を変更するとは思わない。
Mani

10
Array.prototype.sliceすでにコピーを返します。Array.prototype.splice元の配列を変更します。
グイドブーマン2016

2
slice()メソッドは、配列の一部の浅いコピーを新しい配列オブジェクトに返します。Mozilla Developer Networkを参照してください。反対投票。
TheCrazyProgrammer 2017

他の人が言ったように、sliceすでに浅いコピーを返すため、このsubarray実装は不要です。しかし、組み込みオブジェクトをサルがパッチを適用したことにも言及する価値があります。Abdennour TOUMIの回答に関するコメントを参照してください。
daemonexmachina
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.