本文实例讲述了JS数组方法shift()、unshift()用法。分享给大家供大家参考,具体如下:
shift()方法
1. 定义:从数组中删除第一个元素,并返回该元素的值。此方法更改数组的长度。
2. 语法: arr.shift()
3. 参数:/
4. 返回值:从数组中删除的元素(当数组为空时返回undefined)。
代码如下:
方法一:
var arr1 = [1, 2, 3, 4, 'A', 'B', 'C']; var arr2 = []; Array.prototype.copyShift = function() { var result = [], newArr = []; result = this[0]; for(var i = 1; i < this.length; i++) {// 将数组的第二个至最后一项的值赋值给newArr newArr[newArr.length] = this[i]; } for(var i = 0; i < newArr.length; i++) { //newArr赋值给原数组 this[i] = newArr[i]; } this.length = newArr.length; return result; }; console.log(arr1.copyShift()); // 1 console.log(arr1); // [2, 3, 4, 'A', 'B'] console.log(arr2.copyShift()); // undefined console.log(arr2); // []
运行结果:
方法二:将上述代码修改为如下:(去掉中间数组newArr,直接在原数组上操作)
var arr1 = [1, 2, 3, 4, 'A', 'B', 'C']; var arr2 = []; Array.prototype.copyShift = function() { var result = []; result = this[0]; /* for(var i = 1; i < this.length; i++) {// 将数组的第二个至最后一项的值赋值给newArr newArr[newArr.length] = this[i]; } for(var i = 0; i < newArr.length; i++) { //newArr赋值给原数组 this[i] = newArr[i]; } this.length = newArr.length; */ // 将数组的后一项赋值给前一项 for(var i = 0; i < this.length; i++) { this[i] = this[i + 1]; } if(this.length > 1) {//去掉数组最后一项 this.length = this.length - 1; } return result; }; console.log(arr1.copyShift()); // 1 console.log(arr1); // [2, 3, 4, 'A', 'B'] console.log(arr2.copyShift()); // undefined console.log(arr2); // []
运行结果:
unshift()方法
1. 定义:将一个或多个元素添加到数组的开头,并返回新数组的长度。
2. 语法:arr.unshift(element1, ..., elementN)
3. 参数:数组前端添加任意个项
4. 返回值:当一个对象调用该方法时,返回其 length 属性值。
代码如下:
方法一:
var arr1 = [1, 2, 3, 4, 'A', 'B', 'C']; var arr2 = [1, 2, 3, 4]; Array.prototype.copyUnshift = function() { var newArr = [], argLen = arguments.length, len = argLen + this.length; for(var i = 0; i < len; i++) { /* if(i < argLen) { newArr[i] = arguments[i]; } else { newArr[i] = this[i - argLen]; } */ // 上述代码也可写为: newArr[i] = (i < argLen) "//img.jbzj.com/file_images/article/202001/2020118104647461.png" alt="" />//同方法一一样,只不过是for循环以递减的形式 var arr1 = [1, 2, 3, 4, 'A', 'B', 'C']; var arr2 = [1, 2, 3, 4]; Array.prototype.copyUnshift = function() { var newArr = [], argLen = arguments.length, len = argLen + this.length; //同方法一一样,只不过是for循环以递减的形式 for(var i = len - 1; i >= 0; i--) { /* if(i < argLen) { newArr[i] = arguments[i]; } else { newArr[i] = this[i - argLen]; } */ // 上述代码也可写为: newArr[i] = (i < argLen) "htmlcode">var arr1 = [1, 2, 3, 4, 'A', 'B', 'C']; var arr2 = [1, 2, 3, 4]; Array.prototype.copyUnshift = function() { var argLen = arguments.length, len = argLen + this.length; for(var i = len - 1; i >= 0; i--) { /* if(i > argLen - 1) { this[i] = this[i - argLen]; } else { this[i] = arguments[i]; } */ this[i] = (i > argLen - 1) "//img.jbzj.com/file_images/article/202001/2020118104945635.png" alt="" />感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试上述代码运行效果。
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript数组操作技巧总结》、《JavaScript遍历算法与技巧总结》、《javascript面向对象入门教程》、《JavaScript数学运算用法总结》、《JavaScript数据结构与算法技巧总结》及《JavaScript错误与调试技巧总结》
希望本文所述对大家JavaScript程序设计有所帮助。
极乐门资源网 Design By www.ioogu.com
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 张学友《走过1999》2023头版蜚声环球限量编号[低速原抓WAV+CUE][1G]
- 田震《真的田震精品集》头版限量编号24K金碟[低速原抓WAV+CUE][1G]
- 林俊杰《伟大的渺小》华纳[WAV+CUE][1G]
- 谭艳《遗憾DSD》2023 [WAV+CUE][1G]
- Beyond2024《真的见证》头版限量编号MQA-UHQCD[WAV+CUE]
- 瑞鸣唱片2024-《荒城之月》SACD传统民谣[ISO]
- 好薇2024《兵哥哥》1:124K黄金母盘[WAV+CUE]
- 胡歌.2006-珍惜(EP)【步升大风】【FLAC分轨】
- 洪荣宏.2014-拼乎自己看【华特】【WAV+CUE】
- 伊能静.1999-从脆弱到勇敢1987-1996精选2CD【华纳】【WAV+CUE】
- 刘亮鹭《汽车DJ玩主》[WAV+CUE][1.1G]
- 张杰《最接近天堂的地方》天娱传媒[WAV+CUE][1.1G]
- 群星《2022年度发烧天碟》无损黑胶碟 2CD[WAV+CUE][1.4G]
- 罗文1983-罗文甄妮-射雕英雄传(纯银AMCD)[WAV+CUE]
- 群星《亚洲故事香港纯弦》雨果UPMAGCD2024[低速原抓WAV+CUE]