回答:
を見てみましょう 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);
ar
は変更されていないことをここで明示的に言及する価値があるでしょう。 console.log(ar);
// -> [1, 2, 3, 4, 5]
を簡単に使用するには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など)の開発者にとっては、より簡単かもしれません。
Array.prototype.contains
Array.prototype.includes
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']
、これも期待されています。
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);
質問は、実際のために求めている新しい配列私はよりよい解決策を組み合わせることであろうと考えているので、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]
Array.prototype.slice
すでにコピーを返します。Array.prototype.splice
元の配列を変更します。
slice
すでに浅いコピーを返すため、このsubarray
実装は不要です。しかし、組み込みオブジェクトをサルがパッチを適用したことにも言及する価値があります。Abdennour TOUMIの回答に関するコメントを参照してください。