在JavaScript中将数组附加到另​​一个数组

Chr*_*row 97 javascript arrays concatenation

这个问题完全重复:
如何将数组附加到现有的JavaScript数组?

如何在JavaScript中将数组附加到另​​一个数组?

一个人可能会提出这个问题的其他方式:

  • 将数组添加到另一个
  • Concat/Concatenate数组
  • 使用另一个数组扩展数组
  • 将一个数组的内容放入另一个数组中

我花了一些时间寻找这个问题的答案.有时像这些最简单的那些是最难找到答案的,所以我希望在这里添加这个问题,根据这篇博文有很多关键词和短语.请随时使用任何其他有用的信息回答此问题,或编辑下面的关键词和短语.

小智 131

如果要修改原始数组而不是返回新数组,请使用.push()...

array1.push.apply(array1, array2);
array1.push.apply(array1, array3);
Run Code Online (Sandbox Code Playgroud)

我用.apply于阵列的各个成员推23在一次.

要么...

array1.push.apply(array1, array2.concat(array3));
Run Code Online (Sandbox Code Playgroud)

要处理大型数组,您可以批量执行此操作.

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));
}
Run Code Online (Sandbox Code Playgroud)

如果你这么做,请创建一个方法或函数来处理它.

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));
            }
        }
    }
});
Run Code Online (Sandbox Code Playgroud)

并像这样使用它:

array1.pushArrayMembers(array2, array3);
Run Code Online (Sandbox Code Playgroud)

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);
Run Code Online (Sandbox Code Playgroud)

  • 这种方式很糟糕,并且不适用于> 500 ish元素数组 (5认同)
  • tl; dr:`array1 = [] .concat(array1,array2,array3/*,..*/);`更好 (3认同)
  • 我最喜欢重复问题的答案:/sf/ask/96188851/#answer-1374131 (2认同)