JS数组push、unshift、pop、shift方法的实现与使用方法示例


Posted in Javascript onApril 29, 2020

本文实例讲述了JS数组push、unshift、pop、shift方法的实现与使用方法。分享给大家供大家参考,具体如下:

尾部添加(push)

push() 方法将一个或多个元素添加到数组的末尾,并返回该数组的新长度。

从解释中可以看出,push方法只要将要添加的元素依次放到数组的最后即可,不会改变原有数组元素的索引。所以循环参数列表,将新元素依次放到数组的最后即可。

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 ]

头部添加(unshift)

unshift() 方法将一个或多个元素添加到数组的开头,并返回该数组的新长度(该方法修改原有数组)。

向数组的头部添加元素,数组的长度也会发生变化,但不像尾部添加的操作,数组原有元素索引不改变。做头部添加的操作,需要将原有元素的索引向右移动。

例如只添加一位,则需要将数组的每个元素的索引依次向右移一位,假设原来数组长度是4,头部添加一个元素,长度变为5.

所以现在就变成:array.length = 5,而目前array[5 - 1]是最后一个元素,现在由于依次往后移动,所以,array[5]必须是最后一个元素

所以我们可以从数组的最后一位的下一位往前循环,将array[i]赋值为array[i - 1],循环到1停止,将array的第0项赋值为需要添加的值。

过程如下

JS数组push、unshift、pop、shift方法的实现与使用方法示例

具体代码实现:

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(8)
console.log(arr); // [ 8, 1, 2, 3, 4 ]

但上面的代码只实现了一个元素的头部添加,unshift方法支持添加多个元素。例如:

var arr = [1, 2, 3, 4]
arr.unshift(8, 7)
console.log(arr); // [ 8, 7, 1, 2, 3, 4 ]

针对这样的情况,需要知道传入了几个参数,可以从arguments对象入手,思路还是上面的思路:
先以最后生成的数组长度为基准从后往前循环,依次移动元素,然后将新元素依次放到数组的头部

新数组的长度等于原数组的长度 + 参数的个数,从后往前循环,将原数组的最后一位,移动到新数组的最后一位,

因为需要在头部插入数量为入参个数的元素,所以循环的起点为原数组的长度 + 参数的个数,循环的终点为入参的个数。

但由于索引总是比长度少一位,所以起点和终点都需要减1。

现在可以先把循环移动的逻辑写出来

Array.prototype._unshift = function(...value) {
 for (var i = (this.length + arguments.length - 1); i > arguments.length - 1; i--) {
 this[i] = this[i - arguments.length]
 }
}

再思考一下,由于上一步已经移动完了,数组头部的位置已经空出来了,第二步是有几个参数就要插入几个元素。所以现在只需要循环插入就好:

for(var k = 0; k < arguments.length; k++) {
 this[k] = arguments[k]
}

完整的代码如下:

Array.prototype._unshift = function(...value) {
 for (var i = (this.length + arguments.length - 1); i > arguments.length - 1; i--) {
 this[i] = this\[i - arguments.length]
 }
 for(var k = 0; k < arguments.length; k++) {
 this[k] = arguments[k]
 }
 return this.length
}
var arr = [1, 2, 3, 4\]
arr._unshift(9, 8)
console.log(arr); // [ 9, 8, 1, 2, 3, 4 ]

尾部删除 (pop)

`pop() 方法将删除 arrayObject 的最后一个元素,把数组长度减 1,并且返回它删除的元素的值。如果数组已经为空,则 pop() 不改变数组,
并返回 undefined 值。`

这个很好实现,按照定义一步一步做就可以。首先,记录下最后一个元素,便于返回,之后从数组中删除最后一个元素,
将其指向null释放掉,然后将数组的长度减1,最后判断一下是否为空数组。

Array.prototype._pop = function () {
 if (!this.length) {
 return undefined
 }
 var end = this[this.length - 1]
 this[this.length - 1] = null
 this.length = this.length - 1
 return end
}
var arr = [1, 2, 3, 4]
arr._pop()
console.log(arr); // [ 1, 2, 3 ]

头部删除(shift)

shift() 方法用于把数组的第一个元素从其中删除,并返回第一个元素的值。

头部删除,会改变原有数组元素的索引,也就是将未被删除的元素索引都往左移一位,首先要将被删除的元素记录下来便于返回,之后将数组第一个元素指向null,

最后循环数组,移动索引。

Array.prototype._shift = function () {
 if (!this.length) {
 return undefined
 }
 var start = this[0]
 this[0] = null
 for(var i = 0; i < this.length - 1; i++) {
 this[i] = this[i + 1]
 }
 this.length = this.length - 1
 return start
}
var arr = [1, 2, 3, 4]
arr._shift()
console.log(arr); // [ 2, 3, 4 ]

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
jQuery 对象中的类数组操作
Apr 27 Javascript
javascript tips提示框组件实现代码
Nov 19 Javascript
javascript间隔刷新的简单实例
Nov 14 Javascript
textarea 控制输入字符字节数(示例代码)
Dec 27 Javascript
初步了解javascript面向对象
Nov 09 Javascript
jQuery实现宽屏图片轮播实例教程
Nov 24 Javascript
jquery+CSS3实现3D拖拽相册效果
Jul 18 Javascript
webpack+vue.js实现组件化详解
Oct 12 Javascript
JS生成一维码(条形码)功能示例
Jan 19 Javascript
Node.Js中实现端口重用原理详解
May 03 Javascript
简单了解微信小程序的目录结构
Jul 01 Javascript
vue中的计算属性和侦听属性
Nov 06 Javascript
JS实现手写 forEach算法示例
Apr 29 #Javascript
Node.js API详解之 querystring用法实例分析
Apr 29 #Javascript
Node.js API详解之 string_decoder用法实例分析
Apr 29 #Javascript
深入浅析vue全局环境变量和模式
Apr 28 #Javascript
你准备好迎接vue3.0了吗
Apr 28 #Javascript
JavaScript禁止右击保存图片,禁止拖拽图片的实现代码
Apr 28 #Javascript
JavaScript 禁止用户保存图片的实现代码
Apr 28 #Javascript
You might like
雄兵连:第三季确定会出,不过时间未定,鹤熙是第三季的主角!
2020/03/13 国漫
PHP 服务器配置(使用Apache及IIS两种方法)
2009/06/01 PHP
PHP 第二节 数据类型之字符串类型
2012/04/28 PHP
PHP检查端口是否可以被绑定的方法示例
2018/08/09 PHP
jquery 分页控件实现代码
2009/11/30 Javascript
javascript闭包的理解和实例
2010/08/12 Javascript
JQuery之拖拽插件实现代码
2011/04/14 Javascript
JQuery为textarea添加maxlength属性并且兼容IE
2013/04/25 Javascript
jquery实现手风琴效果实例代码
2013/11/15 Javascript
js变量、作用域及内存详解
2014/09/23 Javascript
javascript常用函数归纳整理
2014/10/31 Javascript
简单谈谈jQuery(function(){})与(function(){})(jQuery)
2014/12/19 Javascript
js实现的早期滑动门菜单效果代码
2015/08/27 Javascript
Ajax实现不刷新取最新商品
2017/03/01 Javascript
Vue2.0用户权限控制解决方案
2017/11/29 Javascript
vue 实现强制类型转换 数字类型转为字符串
2019/11/07 Javascript
js实现经典贪吃蛇小游戏
2020/03/19 Javascript
如何利用node转发请求详解
2020/09/17 Javascript
在Python中使用zlib模块进行数据压缩的教程
2015/06/26 Python
Python实现批量下载图片的方法
2015/07/08 Python
qpython3 读取安卓lastpass Cookies
2016/06/19 Python
python实现汉诺塔方法汇总
2016/07/25 Python
用生成器来改写直接返回列表的函数方法
2017/05/25 Python
python读取文本中的坐标方法
2018/10/14 Python
tensorflow将图片保存为tfrecord和tfrecord的读取方式
2020/02/17 Python
CSS3实现DIV圆角效果完整代码
2012/10/10 HTML / CSS
ALDO英国官网:加拿大女鞋品牌
2018/02/19 全球购物
MIRTA官网:手工包,100%意大利制造
2020/02/11 全球购物
网站编辑求职信
2013/10/17 职场文书
幼儿园新年寄语
2014/04/03 职场文书
企业安全生产演讲稿
2014/05/09 职场文书
助人为乐好少年事迹材料
2014/08/18 职场文书
教师个人学习总结
2015/02/11 职场文书
《认识钟表》教学反思
2016/02/16 职场文书
SQL实现LeetCode(176.第二高薪水)
2021/08/04 MySQL
Javascript设计模式之原型模式详细
2021/10/05 Javascript