JS数组push、unshift、pop、shift操作详解及实例
版权申诉
92 浏览量
更新于2024-09-11
收藏 108KB PDF 举报
在JavaScript中,数组是用于存储一组有序数据的数据结构。在处理数组时,有时我们需要在数组的开头或结尾添加或删除元素。JS数组提供了几个内置方法来实现这些操作,分别是`push`、`unshift`、`pop`和`shift`。下面我们将详细探讨这些方法的实现原理和使用方法。
1. 尾部添加 - push
`push`方法用于在数组的末尾添加一个或多个元素,并返回数组的新长度。这个方法不会改变原有数组元素的索引。实现`push`的方法如下:
```javascript
Array.prototype._push = function (value) {
for (var i = 0; i < arguments.length; i++) {
this[this.length] = arguments[i];
}
return this.length;
}
var arr = [1, 2, 3, 4];
arr._push(9, 8);
console.log(arr); // [1, 2, 3, 4, 9, 8]
```
2. 头部添加 - unshift
`unshift`方法用于在数组的开头添加一个或多个元素,并返回数组的新长度。这个方法会改变原有数组元素的索引。实现`unshift`的方法如下:
```javascript
Array.prototype._unshift = function (value) {
for (let i = this.length; i > 0; i--) {
this[i] = this[i - 1];
}
this[0] = value;
return this.length;
}
var arr = [1, 2, 3, 4];
arr._unshift(9, 8);
console.log(arr); // [9, 8, 1, 2, 3, 4]
```
3. 尾部删除 - pop
`pop`方法用于删除并返回数组的最后一个元素,数组的长度会减一。实现`pop`的方法很简单,因为只需要移除数组的最后一个元素即可:
```javascript
Array.prototype._pop = function () {
if (this.length === 0) return undefined;
var lastItem = this[this.length - 1];
delete this[this.length - 1];
this.length--;
return lastItem;
}
var arr = [1, 2, 3, 4];
console.log(arr._pop()); // 4
console.log(arr); // [1, 2, 3]
```
4. 头部删除 - shift
`shift`方法用于删除并返回数组的第一个元素,数组的长度也会减一。实现`shift`的方法涉及到对数组中所有元素的重新排列:
```javascript
Array.prototype._shift = function () {
if (this.length === 0) return undefined;
var firstItem = this[0];
for (let i = 1; i < this.length; i++) {
this[i - 1] = this[i];
}
delete this[this.length - 1];
this.length--;
return firstItem;
}
var arr = [1, 2, 3, 4];
console.log(arr._shift()); // 1
console.log(arr); // [2, 3, 4]
```
以上四个方法都是对数组操作的重要组成部分,它们可以帮助我们方便地在数组的两端进行元素的添加和删除。在实际开发中,了解这些方法的工作原理和使用方式,能帮助我们更高效地处理数组数据。需要注意的是,这些方法都会直接修改原数组,而不是创建新的数组副本,所以在某些情况下可能需要先复制数组再进行操作。
2020-10-15 上传
点击了解资源详情
2020-10-26 上传
点击了解资源详情
2021-07-15 上传
2021-07-15 上传
2016-04-11 上传
2020-10-18 上传
2021-07-16 上传
weixin_38558186
- 粉丝: 4
- 资源: 878
最新资源
- 探索AVL树算法:以Faculdade Senac Porto Alegre实践为例
- 小学语文教学新工具:创新黑板设计解析
- Minecraft服务器管理新插件ServerForms发布
- MATLAB基因网络模型代码实现及开源分享
- 全方位技术项目源码合集:***报名系统
- Phalcon框架实战案例分析
- MATLAB与Python结合实现短期电力负荷预测的DAT300项目解析
- 市场营销教学专用查询装置设计方案
- 随身WiFi高通210 MS8909设备的Root引导文件破解攻略
- 实现服务器端级联:modella与leveldb适配器的应用
- Oracle Linux安装必备依赖包清单与步骤
- Shyer项目:寻找喜欢的聊天伙伴
- MEAN堆栈入门项目: postings-app
- 在线WPS办公功能全接触及应用示例
- 新型带储订盒订书机设计文档
- VB多媒体教学演示系统源代码及技术项目资源大全