似乎没有办法用另一个数组来扩展一个现有的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)。
注意:这不是“如何将内容追加到数组?”这里的目标是将一个数组的全部内容添加到另一个数组中,并做到“就地”,即不复制扩展数组的所有元素。
我觉得最近最优雅的是:
arr1.push(...arr2);
MDN上关于扩展操作符的文章在ES2015 (ES6)中提到了这种漂亮的甜美方式:
更好的推动
示例:push通常用于将一个数组推入到现有数组的末尾
数组中。在ES5中,这通常是这样做的:
Var arr1 = [0,1,2];
Var arr2 = [3,4,5];
//将arr2中的所有项追加到arr1
Array.prototype.push。应用(arr1 arr2);
在ES6中,这变成:
Var arr1 = [0,1,2];
Var arr2 = [3,4,5];
arr1.push(…arr2);
请注意arr2不能太大(保持在大约100,000项以下),因为根据jcdude的回答,调用堆栈会溢出。
你可以创建一个polyfill for extend,如下所示。它会添加到数组中;In-place并返回自身,这样就可以链接其他方法。
如果(Array.prototype。Extend === undefined) {
Array.prototype.extend = function(other) {
this.push。应用(这个参数。长度> 1 ?论据:其他);
返回;
};
}
函数print() {
document.body.innerHTML += [].map。调用(参数,函数(项){
返回typeof item === 'object' ?JSON.stringify(item): item;
})。Join (' ') + '\n';
}
document.body.innerHTML = ";
Var a = [1,2,3];
Var b = [4,5,6];
打印(“Concat”);
print(“(1)”,a.concat (b));
print(“(2)”,a.concat (b));
Print ('(3)', a.c concat(4,5,6));
打印(“\ nExtend”);
print(“(1)”,a.extend (b));
print(“(2)”,a.extend (b));
Print ('(3)', a.extend(4,5,6));
身体{
字体类型:等宽字体;
空白:前;
}
2018年更新:更好的答案是我的一个更新的答案:A .push(…b)。不要再给这个投票了,因为它从来没有真正回答过这个问题,但它是2015年关于谷歌第一次点击的黑客攻击:)
对于那些仅仅搜索“JavaScript数组扩展”并到达这里的人来说,您可以很好地使用array .concat。
var a = [1, 2, 3];
a = a.concat([5, 4, 3]);
Concat将返回一个新数组的副本,这是线程启动者不想要的。但您可能并不关心(当然对于大多数用途来说,这是可以的)。
ECMAScript 6中还有一些很好的扩展操作符:
const a = [1, 2, 3];
const b = [...a, 5, 4, 3];
(它也复制。)
合并两个以上数组的另一种解决方案
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]
答案非常简单。
>>> a = [1, 2]
[1, 2]
>>> b = [3, 4, 5]
[3, 4, 5]
>>> SOMETHING HERE
(The following code will combine the two arrays.)
a = a.concat(b);
>>> a
[1, 2, 3, 4, 5]
Concat的作用与JavaScript字符串连接非常相似。它将返回您在调用函数的数组末尾放入concat函数的参数的组合。关键是你必须把返回值赋给一个变量,否则它就会丢失。例如,
a.concat(b); <--- This does absolutely nothing since it is just returning the combined arrays, but it doesn't do anything with it.