Movatterモバイル変換


[0]ホーム

URL:


MDN Web Docs

此页面由社区从英文翻译而来。了解更多并加入 MDN Web Docs 社区。

Array.prototype.unshift()

BaselineWidely available

unshift() 方法将指定元素添加到数组的开头,并返回数组的新长度。

尝试一下

const array1 = [1, 2, 3];console.log(array1.unshift(4, 5));// Expected output: 5console.log(array1);// Expected output: Array [4, 5, 1, 2, 3]

语法

js
unshift()unshift(element1)unshift(element1, element2)unshift(element1, element2, /* …, */ elementN)

参数

element1、…、elementN

添加到arr 开头的元素。

返回值

返回调用方法对象的新length 属性。

描述

unshift() 方法将给定的值插入到类数组对象的开头。

Array.prototype.push() 有着和unshift() 相似的行为,但是其将元素插入到数组的末尾。

请注意,如果多个元素作为参数传递,它们将被插入到对象开头的块中,与它们作为参数传递的顺序完全相同。因此,调用一次unshift() 方法并传递n 个参数,与调用n 次并传递1 个参数(例如使用循环),不会产生相同的结果。

请看示例:

js
let arr = [4, 5, 6];arr.unshift(1, 2, 3);console.log(arr);// [1, 2, 3, 4, 5, 6]arr = [4, 5, 6]; // 重置数组arr.unshift(1);arr.unshift(2);arr.unshift(3);console.log(arr);// [3, 2, 1, 4, 5, 6]

unshift() 方法是通用的。它只期望this 值具有length 属性和整数键属性。虽然字符串也是类似于数组的,但这个方法不适用于它们,因为字符串是不可变的。

示例

使用 unshift()

js
const arr = [1, 2];arr.unshift(0); // 调用的结果是 3,这是新的数组长度。// 数组是 [0, 1, 2]arr.unshift(-2, -1); // 新的数组长度是 5// 数组是 [-2, -1, 0, 1, 2]arr.unshift([-4, -3]); // 新的数组长度是 6// 数组是 [[-4, -3], -2, -1, 0, 1, 2]arr.unshift([-7, -6], [-5]); // 新的数组长度是 8// 数组是 [ [-7, -6], [-5], [-4, -3], -2, -1, 0, 1, 2 ]

在非数组对象中使用 unshift()

unshift 方法会读取thislength 属性。然后,它将0length - 1 范围内的所有属性按参数数量右移,并将每个索引从0 开始,并将参数传递给unshift()。最后,它将length 设置为之前的长度加上前置元素的数量。

js
const arrayLike = {  length: 3,  unrelated: "foo",  2: 4,};Array.prototype.unshift.call(arrayLike, 1, 2);console.log(arrayLike);// { '0': 1, '1': 2, '4': 4, length: 5, unrelated: 'foo' }const plainObj = {};// 这里没有长度属性,所以这里的长的为 0Array.prototype.unshift.call(plainObj, 1, 2);console.log(plainObj);// { '0': 1, '1': 2, length: 2 }

规范

Specification
ECMAScript® 2026 Language Specification
# sec-array.prototype.unshift

浏览器兼容性

参见

Help improve MDN

Learn how to contribute.

This page was last modified on byMDN contributors.


[8]ページ先頭

©2009-2025 Movatter.jp