我需要在数组的开头添加或预加元素。

例如,如果我的数组如下所示:

[23, 45, 12, 67]

AJAX调用的响应是34,我希望更新后的数组如下所示:

[34, 23, 45, 12, 67]

目前我计划这样做:

var newArray = [];
newArray.push(response);

for (var i = 0; i < theArray.length; i++) {
    newArray.push(theArray[i]);
}

theArray = newArray;
delete newArray;

有更好的方法吗?JavaScript是否有任何内置功能来实现这一点?

我的方法的复杂性是O(n),看到更好的实现会非常有趣。


当前回答

变量a=[23,45,12,67];a.未移位(34);console.log(a);//[34, 23, 45, 12, 67]

其他回答

如果需要在数组的开头连续插入元素,那么使用push语句后跟一个反向调用会更快,而不是一直调用unshift。

基准测试:http://jsben.ch/kLIYf

如果要将数组中的元素推送到数组的开头,请使用<func>.apply(<this>,<array of args>):

常量arr=[1,2];取消申请(arr,[3,4]);控制台日志(arr);//[3, 4, 1, 2]

无突变

实际上,所有的unshift/push和shift/pop都会改变源数组。

unshift/push从开始/结束向现有数组添加一个项,并从数组的开始/结束移除一个项。

但是,很少有方法可以在没有变异的情况下将项目添加到数组中。结果是一个新数组,要添加到数组末尾,请使用以下代码:

const originArray = ['one', 'two', 'three'];
const newItem = 4;

const newArray = originArray.concat(newItem); // ES5
const newArray2 = [...originArray, newItem]; // ES6+

要添加到原始数组的开头,请使用以下代码:

const originArray = ['one', 'two', 'three'];
const newItem = 0;

const newArray = (originArray.slice().reverse().concat(newItem)).reverse(); // ES5
const newArray2 = [newItem, ...originArray]; // ES6+

使用上述方法,您可以在没有变异的情况下添加到数组的开头/结尾。

您有一个数组:var arr=[23,45,12,67];

要将项目添加到开头,需要使用拼接:

var arr=[23,45,12,67];arr.splice(0,0,34)控制台日志(arr);

快速付款表:

shift/unshift和push/pop这两个术语可能有点令人困惑,至少对于不熟悉C语言编程的人来说是如此。

如果您不熟悉该术语,以下是替代术语的快速翻译,可能更容易记住:

* array_unshift()  -  (aka Prepend ;; InsertBefore ;; InsertAtBegin )     
* array_shift()    -  (aka UnPrepend ;; RemoveBefore  ;; RemoveFromBegin )

* array_push()     -  (aka Append ;; InsertAfter   ;; InsertAtEnd )     
* array_pop()      -  (aka UnAppend ;; RemoveAfter   ;; RemoveFromEnd )