亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

更多QQ空间微信QQ好友腾讯朋友复制链接
您的位置:首頁(yè)/技術(shù)文章
文章詳情頁(yè)

JS數(shù)組push、unshift、pop、shift方法的實(shí)現(xiàn)與使用方法示例

【字号: 作者:豬豬瀏覽:105日期:2024-05-11 08:56:10

本文實(shí)例講述了JS數(shù)組push、unshift、pop、shift方法的實(shí)現(xiàn)與使用方法。分享給大家供大家參考,具體如下:

尾部添加(push)

push() 方法將一個(gè)或多個(gè)元素添加到數(shù)組的末尾,并返回該數(shù)組的新長(zhǎng)度。

從解釋中可以看出,push方法只要將要添加的元素依次放到數(shù)組的最后即可,不會(huì)改變?cè)袛?shù)組元素的索引。所以循環(huán)參數(shù)列表,將新元素依次放到數(shù)組的最后即可。

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() 方法將一個(gè)或多個(gè)元素添加到數(shù)組的開(kāi)頭,并返回該數(shù)組的新長(zhǎng)度(該方法修改原有數(shù)組)。

向數(shù)組的頭部添加元素,數(shù)組的長(zhǎng)度也會(huì)發(fā)生變化,但不像尾部添加的操作,數(shù)組原有元素索引不改變。做頭部添加的操作,需要將原有元素的索引向右移動(dòng)。

例如只添加一位,則需要將數(shù)組的每個(gè)元素的索引依次向右移一位,假設(shè)原來(lái)數(shù)組長(zhǎng)度是4,頭部添加一個(gè)元素,長(zhǎng)度變?yōu)?.

所以現(xiàn)在就變成:array.length = 5,而目前array[5 - 1]是最后一個(gè)元素,現(xiàn)在由于依次往后移動(dòng),所以,array[5]必須是最后一個(gè)元素

所以我們可以從數(shù)組的最后一位的下一位往前循環(huán),將array[i]賦值為array[i - 1],循環(huán)到1停止,將array的第0項(xiàng)賦值為需要添加的值。

過(guò)程如下

JS數(shù)組push、unshift、pop、shift方法的實(shí)現(xiàn)與使用方法示例

具體代碼實(shí)現(xiàn):

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 ]

但上面的代碼只實(shí)現(xiàn)了一個(gè)元素的頭部添加,unshift方法支持添加多個(gè)元素。例如:

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

針對(duì)這樣的情況,需要知道傳入了幾個(gè)參數(shù),可以從arguments對(duì)象入手,思路還是上面的思路:先以最后生成的數(shù)組長(zhǎng)度為基準(zhǔn)從后往前循環(huán),依次移動(dòng)元素,然后將新元素依次放到數(shù)組的頭部

新數(shù)組的長(zhǎng)度等于原數(shù)組的長(zhǎng)度 + 參數(shù)的個(gè)數(shù),從后往前循環(huán),將原數(shù)組的最后一位,移動(dòng)到新數(shù)組的最后一位,

因?yàn)樾枰陬^部插入數(shù)量為入?yún)€(gè)數(shù)的元素,所以循環(huán)的起點(diǎn)為原數(shù)組的長(zhǎng)度 + 參數(shù)的個(gè)數(shù),循環(huán)的終點(diǎn)為入?yún)⒌膫€(gè)數(shù)。

但由于索引總是比長(zhǎng)度少一位,所以起點(diǎn)和終點(diǎn)都需要減1。

現(xiàn)在可以先把循環(huán)移動(dòng)的邏輯寫(xiě)出來(lái)

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

再思考一下,由于上一步已經(jīng)移動(dòng)完了,數(shù)組頭部的位置已經(jīng)空出來(lái)了,第二步是有幾個(gè)參數(shù)就要插入幾個(gè)元素。所以現(xiàn)在只需要循環(huán)插入就好:

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 的最后一個(gè)元素,把數(shù)組長(zhǎng)度減 1,并且返回它刪除的元素的值。如果數(shù)組已經(jīng)為空,則 pop() 不改變數(shù)組,并返回 undefined 值。`

這個(gè)很好實(shí)現(xiàn),按照定義一步一步做就可以。首先,記錄下最后一個(gè)元素,便于返回,之后從數(shù)組中刪除最后一個(gè)元素,將其指向null釋放掉,然后將數(shù)組的長(zhǎng)度減1,最后判斷一下是否為空數(shù)組。

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() 方法用于把數(shù)組的第一個(gè)元素從其中刪除,并返回第一個(gè)元素的值。

頭部刪除,會(huì)改變?cè)袛?shù)組元素的索引,也就是將未被刪除的元素索引都往左移一位,首先要將被刪除的元素記錄下來(lái)便于返回,之后將數(shù)組第一個(gè)元素指向null,

最后循環(huán)數(shù)組,移動(dòng)索引。

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代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測(cè)試上述代碼運(yùn)行效果。

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《JavaScript數(shù)組操作技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《javascript面向?qū)ο笕腴T(mén)教程》、《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》及《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 又黄又爽的成人免费网站 | 国产免费久久精品久久久 | 毛片性生活| 国产在线麻豆精品观看 | 一级做a爰片性色毛片视频图片 | 在线视频 日韩 | 麻豆md国产在线观看 | 亚洲伦理中文字幕一区 | 精品午夜寂寞影院在线观看 | 91精品视频网 | 久久青草18免费观看网站 | 97麻豆精品国产自产在线观看 | 日本中文不卡 | 国产精品日韩欧美一区二区三区 | 久久国产精品超级碰碰热 | 亚洲欧美日韩在线中文一 | 精品美女模特在线网站 | 污网站大全 | 亚洲综合网在线观看 | 国产成人精品视频午夜 | 在线看黄网| 黄色网欧美 | 免费一级欧美片片线观看 | 91在线播放视频 | 欧美日韩亚洲区久久综合 | 品爱网在线观看视频免费视频 | 亚洲精品不卡视频 | 成人免费在线视频网站 | 久草视频新 | 4虎成人| 国产成人yy免费视频 | 国产丰满主播丝袜勾搭秀 | 日本免费大片免费视频 | 亚洲毛片视频 | 国产青草视频 | 在线一区免费播放 | 免费黄色毛片 | 成人黄色一级视频 | 丁香婷婷综合网 | 久久亚洲美女久久久久 | 成人网mm视频在线观看 |