本文實(shí)例講述了JS數(shù)組方法shift()、unshift()用法。分享給大家供大家參考,具體如下:
公司主營(yíng)業(yè)務(wù):網(wǎng)站制作、網(wǎng)站建設(shè)、移動(dòng)網(wǎng)站開(kāi)發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開(kāi)放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來(lái)的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來(lái)驚喜。創(chuàng)新互聯(lián)推出廣宗免費(fèi)做網(wǎng)站回饋大家。
1. 定義:從數(shù)組中刪除第一個(gè)元素,并返回該元素的值。此方法更改數(shù)組的長(zhǎng)度。
2. 語(yǔ)法: arr.shift()
3. 參數(shù):/
4. 返回值:從數(shù)組中刪除的元素(當(dāng)數(shù)組為空時(shí)返回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++) {// 將數(shù)組的第二個(gè)至最后一項(xiàng)的值賦值給newArr newArr[newArr.length] = this[i]; } for(var i = 0; i < newArr.length; i++) { //newArr賦值給原數(shù)組 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); // []
運(yùn)行結(jié)果:
方法二:將上述代碼修改為如下:(去掉中間數(shù)組newArr,直接在原數(shù)組上操作)
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++) {// 將數(shù)組的第二個(gè)至最后一項(xiàng)的值賦值給newArr newArr[newArr.length] = this[i]; } for(var i = 0; i < newArr.length; i++) { //newArr賦值給原數(shù)組 this[i] = newArr[i]; } this.length = newArr.length; */ // 將數(shù)組的后一項(xiàng)賦值給前一項(xiàng) for(var i = 0; i < this.length; i++) { this[i] = this[i + 1]; } if(this.length > 1) {//去掉數(shù)組最后一項(xiàng) 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); // []
運(yùn)行結(jié)果:
1. 定義:將一個(gè)或多個(gè)元素添加到數(shù)組的開(kāi)頭,并返回新數(shù)組的長(zhǎng)度。
2. 語(yǔ)法:arr.unshift(element1, ..., elementN)
3. 參數(shù):數(shù)組前端添加任意個(gè)項(xiàng)
4. 返回值:當(dāng)一個(gè)對(duì)象調(diào)用該方法時(shí),返回其 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]; } */ // 上述代碼也可寫(xiě)為: newArr[i] = (i < argLen) ? arguments[i] : this[i - argLen]; } for(var i = 0; i < len; i++) { this[i] = newArr[i]; } return len; }; console.log(arr1.copyUnshift('XXX', 'YYY', 'ZZZ')); // 10 console.log(arr1); // ['XXX', 'YYY', 'ZZZ', 1, 2, 3, 4, 'A', 'B'] console.log(arr2.copyUnshift()); // 4 console.log(arr2); // [1, 2, 3, 4]
運(yùn)行結(jié)果:
//同方法一一樣,只不過(guò)是for循環(huán)以遞減的形式 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; //同方法一一樣,只不過(guò)是for循環(huán)以遞減的形式 for(var i = len - 1; i >= 0; i--) { /* if(i < argLen) { newArr[i] = arguments[i]; } else { newArr[i] = this[i - argLen]; } */ // 上述代碼也可寫(xiě)為: newArr[i] = (i < argLen) ? arguments[i] : this[i - argLen]; } for(var i = 0; i < len; i++) { this[i] = newArr[i]; } return len; };
接上遞減形式的for循環(huán),進(jìn)一步可修改為:
方法二:直接修改原數(shù)組,不借助中間數(shù)組
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) ? this[i - argLen] : arguments[i]; } return len; }; console.log(arr1.copyUnshift('XXX', 'YYY', 'ZZZ')); // 10 console.log(arr1); // ['XXX', 'YYY', 'ZZZ', 1, 2, 3, 4, 'A', 'B'] console.log(arr2.copyUnshift()); // 4 console.log(arr2); // [1, 2, 3, 4]
運(yùn)行結(jié)果:
感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測(cè)試上述代碼運(yùn)行效果。
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《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ì)有所幫助。
網(wǎng)頁(yè)名稱:JS數(shù)組方法shift()、unshift()用法實(shí)例分析
當(dāng)前路徑:http://aaarwkj.com/article18/pdhpgp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄、、外貿(mào)建站、手機(jī)網(wǎng)站建設(shè)、定制開(kāi)發(fā)、網(wǎng)站內(nèi)鏈
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)