似乎没有办法用另一个数组来扩展一个现有的JavaScript数组,即模仿Python的extend方法。
我想达到以下几点:
>>> a = [1, 2]
[1, 2]
>>> b = [3, 4, 5]
[3, 4, 5]
>>> SOMETHING HERE
>>> a
[1, 2, 3, 4, 5]
我知道有一个a.c concat(b)方法,但它创建了一个新数组,而不是简单地扩展第一个数组。我想要一个算法,有效地工作时,a明显大于b(即一个不复制a)。
注意:这不是“如何将内容追加到数组?”这里的目标是将一个数组的全部内容添加到另一个数组中,并做到“就地”,即不复制扩展数组的所有元素。
push方法可以接受多个参数。你可以使用展开操作符将第二个数组的所有元素作为参数传递给.push:
>>> a.push(...b)
如果你的浏览器不支持ECMAScript 6,你可以使用.apply来代替:
>>> a.push.apply(a, b)
或者,如果你觉得更清楚的话:
>>> Array.prototype.push.apply(a,b)
请注意,如果数组b太长,所有这些解决方案都将失败,并出现堆栈溢出错误(问题开始于大约100,000个元素,取决于浏览器)。
如果不能保证b足够短,则应该使用另一个答案中描述的基于循环的标准技术。
合并两个以上数组的另一种解决方案
var a = [1, 2],
b = [3, 4, 5],
c = [6, 7];
// Merge the contents of multiple arrays together into the first array
var mergeArrays = function() {
var i, len = arguments.length;
if (len > 1) {
for (i = 1; i < len; i++) {
arguments[0].push.apply(arguments[0], arguments[i]);
}
}
};
然后调用并打印为:
mergeArrays(a, b, c);
console.log(a)
输出将是:数组[1,2,3,4,5,6,7]
我添加了这个答案,因为尽管这个问题没有创建一个新数组,但几乎每个答案都忽略了它。
现代JavaScript可以很好地处理数组等可迭代对象。这使得在此基础上实现一个版本的concat成为可能,并在逻辑上跨越数组数据的参数。
下面的例子使用了iter-ops库,它具有这样的逻辑:
import {pipe, concat} from 'iter-ops';
const i = pipe(
originalArray,
concat(array2, array3, array4, ...)
); //=> Iterable
for(const a of i) {
console.log(a); // iterate over values from all arrays
}
上面没有创建新数组。操作符concat将遍历原始数组,然后按照指定的顺序自动继续到array2、array3等等。
就内存使用而言,这是最有效的连接数组的方法。
如果在最后,你决定将它转换为一个实际的物理数组,你可以通过展开操作符或array .from来实现:
const fullArray1 = [...i]; // pulls all values from iterable, into a new array
const fullArray2 = Array.from(i); // does the same