Добавить массив в другой массив в JavaScript

Этот вопрос является точным дубликатом:
Как добавить массив к существующему массиву JavaScript?

Как добавить массив в другой массив в JavaScript?

Другие способы, которыми человек может ответить на этот вопрос:

  • Добавить массив в другой
  • Конкатентные/Конкатенатные массивы
  • Расширить массив с помощью другого массива
  • Поместите содержимое одного массива в другой массив

Я потратил некоторое время на поиск ответа на этот вопрос. Иногда самые простые из них, такие как эти, наиболее трудно найти ответы, поэтому я добавляю вопрос, надеюсь, с большим количеством ключевых слов и фраз в этом сообщении в блоге. Не стесняйтесь отвечать на этот вопрос любой другой полезной информацией или редактировать ключевые слова и фразы ниже.

Ответ 1

Если вы хотите изменить исходный массив вместо возврата нового массива, используйте .push()...

array1.push.apply(array1, array2);
array1.push.apply(array1, array3);

Я использовал .apply для одновременного нажатия отдельных элементов массивов 2 и 3.

или...

array1.push.apply(array1, array2.concat(array3));

Чтобы справиться с большими массивами, вы можете делать это партиями.

for (var n = 0, to_add = array2.concat(array3); n < to_add.length; n+=300) {
    array1.push.apply(array1, to_add.slice(n, n+300));
}

Если вы делаете это много, создайте метод или функцию для его обработки.

var push_apply = Function.apply.bind([].push);
var slice_call = Function.call.bind([].slice);

Object.defineProperty(Array.prototype, "pushArrayMembers", {
    value: function() {
        for (var i = 0; i < arguments.length; i++) {
            var to_add = arguments[i];
            for (var n = 0; n < to_add.length; n+=300) {
                push_apply(this, slice_call(to_add, n, n+300));
            }
        }
    }
});

и используйте его следующим образом:

array1.pushArrayMembers(array2, array3);

var push_apply = Function.apply.bind([].push);
var slice_call = Function.call.bind([].slice);

Object.defineProperty(Array.prototype, "pushArrayMembers", {
    value: function() {
        for (var i = 0; i < arguments.length; i++) {
            var to_add = arguments[i];
            for (var n = 0; n < to_add.length; n+=300) {
                push_apply(this, slice_call(to_add, n, n+300));
            }
        }
    }
});

var array1 = ['a','b','c'];
var array2 = ['d','e','f'];
var array3 = ['g','h','i'];

array1.pushArrayMembers(array2, array3);

document.body.textContent = JSON.stringify(array1, null, 4);