JS中Array數(shù)組學(xué)習(xí)的總結(jié)
引用類型分為Object類型(所謂的對(duì)象),Array類型(本文談的數(shù)組),F(xiàn)unction類型等。
那么,數(shù)組是干啥的呢?在我看來(lái),它是用來(lái)保存數(shù)據(jù)的。
一、聲明一個(gè)數(shù)組:
1、構(gòu)造函數(shù) var colors=new Array();簡(jiǎn)寫的話可以省略new,即var colors=Array();
2、數(shù)組字面量 var colors=["black","green","pink"];
二、讀取和設(shè)置數(shù)組的值:
讀?。篶olors[x];參數(shù)x為0~colors.length-1;
設(shè)置的話直接給colors[x]=進(jìn)行賦值就好,這樣會(huì)覆蓋之前的數(shù)值哦;
三、在這里簡(jiǎn)單說(shuō)說(shuō)length的用法:
colors.length獲取數(shù)組的長(zhǎng)度,也可以說(shuō)是數(shù)組有幾項(xiàng),如果說(shuō)一個(gè)數(shù)組有7項(xiàng),但是你寫入了colors.length=2,那么就會(huì)刪除后面的5項(xiàng);
利用length屬性也可以為數(shù)組最后添加數(shù)據(jù):colors[colors.length]=進(jìn)行賦值;
四、數(shù)組中的操作:
方法 | 作用 | 返回值 |
Array.push(x,y,z) | 把xyz添加到數(shù)組末尾 | 新數(shù)組長(zhǎng)度 |
Array.pop() | 移除數(shù)組最后一項(xiàng) | 移除的最后一項(xiàng) |
Array.shift() | 移除數(shù)組第一項(xiàng) | 移除的第一項(xiàng) |
Array.unshift(a,b,c) | 在數(shù)組前端添加a,b,c | 新數(shù)組長(zhǎng)度 |
Array.reverse() | 反轉(zhuǎn)數(shù)組 | 反轉(zhuǎn)后的新數(shù)組 |
Array.sort() | 對(duì)數(shù)組中每一項(xiàng)的字符串進(jìn)行升序排列 | 重新排序后的數(shù)組 |
Array.concat(a,b,c) | 連接數(shù)組 | 返回連接好的新數(shù)組 |
Array.slice(1,n) | 截取數(shù)組,從1到n,1和n為索引值 | 返回截取的數(shù)組(在這里返回從1開(kāi)始,到n之前結(jié)束) |
Array.indexOf(a,start) | 查找a的所在的位置,從start開(kāi)始 | 返回a所在的索引值,如果沒(méi)有查找到則返回-1 |
Array.lastIndexOf(a,atart) | 與indexOf相反,lastIndexOf從末尾開(kāi)始查找 | 返回a所在的索引值,如果沒(méi)有查找到則返回-1 |
splice()方法單拿出來(lái)說(shuō)說(shuō)。為什么單拿出來(lái)?因?yàn)榕#?/p>
1.刪除。接受兩個(gè)參數(shù):要?jiǎng)h除第一項(xiàng)的位置和要?jiǎng)h除的項(xiàng)數(shù);
例:splice(1,2),就是要?jiǎng)h除數(shù)組種的2,3項(xiàng);
2.插入。接受三個(gè)參數(shù):起始位置,0,要插入的項(xiàng)。
例:splice(2,0,"red","green"),會(huì)在數(shù)組索引值為2的位置插入red和green。
3.替換。接受三個(gè)參數(shù):起始位置,要?jiǎng)h除的項(xiàng)數(shù),要插入的項(xiàng)。
例:splice(2,1,"red","green"),刪除索引值為2這一項(xiàng),添加red和green。
tips:sort()用法實(shí)例:按升序排列數(shù)組 function compare(val1,val2){ if(val1<val2){ return -1; }else if(val1>val2){ return 1; }else{ retuen 0 } } var num=[0,2,9,3,1]; num.sort(compare); alert(num);//0,1,2,3,9
五。數(shù)組中的迭代方法
1.every()和some():
查詢數(shù)組中的每一項(xiàng)是否滿足條件,如果每一項(xiàng)都返回true,則result返回true。 var numbers=[0,1,2,3,4]; var result=numbers.every(function(item,index,array){ return (item>2) }) alert(result);//false 查詢數(shù)組中的每一項(xiàng)是否滿足條件,如果有一項(xiàng)都返回true,則result返回true。 var numbers=[0,1,2,3,4]; var result=numbers.some(function(item,index,array){ return (item>2) }) alert(result);//true
2.filter():
該方法會(huì)返回結(jié)果為true的項(xiàng)組成的數(shù)組;
3.map():
var result=numbers.map(function(item,index,array){ return item*2; })
返回?cái)?shù)組執(zhí)行完參數(shù)之后的新數(shù)組。
六、歸并
Array.reduce()
var numbers=[1,2,3,4,5]; var sum=numbers.reduce(function(prev,cur,index,array){ return prev+cur }) alert(sum);
在上個(gè)例子中,reduce()接受四個(gè)參數(shù),第一個(gè)參數(shù)是數(shù)組的第一項(xiàng),第二個(gè)參數(shù)是數(shù)組的第二項(xiàng);
第一次執(zhí)行函數(shù),prev是1,cur是2,第二次執(zhí)行,prev是3(1+2的結(jié)果),cur是3。
Array.reduceRight()。和reduce類似。只不過(guò)從數(shù)組右側(cè)開(kāi)始。
以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持腳本之家!
相關(guān)文章
當(dāng)鼠標(biāo)移動(dòng)到圖片上時(shí)跟隨鼠標(biāo)顯示放大的圖片效果
當(dāng)鼠標(biāo)移動(dòng)到圖片上時(shí),跟隨鼠標(biāo)顯示放大顯示的圖片,具體效果情況截圖,另附送源碼,感興趣的朋友可以學(xué)習(xí)下哈2013-06-06jquery事件機(jī)制擴(kuò)展插件 jquery鼠標(biāo)右鍵事件
jquery其實(shí)本身的事件機(jī)制就很完善了,包括了單擊,雙擊,鼠標(biāo)移入,鼠標(biāo)移出等。但是卻少了一個(gè)做事件。就是鼠標(biāo)右擊事件。當(dāng)然大家也是直接用偵聽(tīng)鼠標(biāo)按下事件,然后通過(guò)if來(lái)判斷執(zhí)行相應(yīng)的函數(shù)。造成鼠標(biāo)右擊事件的效果2011-12-12JQuery顯示、隱藏div的幾種方法簡(jiǎn)明總結(jié)
這篇文章主要介紹了JQuery顯示、隱藏div的幾種方法簡(jiǎn)明總結(jié),本文總結(jié)了控制style、控制CSS、JQuery自帶方法等幾種顯示、隱藏div的方法,需要的朋友可以參考下2015-04-04jQuery+html5實(shí)現(xiàn)div彈出層并遮罩背景
今天在項(xiàng)目中用到了一個(gè)很好的div彈出層效果,jQuery+html5實(shí)現(xiàn)div彈出層并遮罩背景,效果非常棒,拿出來(lái)和大家一起分享!2015-04-04完美解決jQuery fancybox ie 無(wú)法顯示關(guān)閉按鈕的問(wèn)題
下面小編就為大家?guī)?lái)一篇完美解決jQuery fancybox ie 無(wú)法顯示關(guān)閉按鈕的問(wèn)題。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-11-11jQuery插件WebUploader實(shí)現(xiàn)文件上傳
這篇文章主要為大家詳細(xì)介紹了jQuery插件WebUploader實(shí)現(xiàn)文件上傳,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11jQuery實(shí)現(xiàn)三級(jí)聯(lián)動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了jQuery實(shí)現(xiàn)三級(jí)聯(lián)動(dòng)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03jQuery簡(jiǎn)單實(shí)現(xiàn)兩級(jí)下拉菜單效果代碼
這篇文章主要介紹了jQuery簡(jiǎn)單實(shí)現(xiàn)兩級(jí)下拉菜單效果代碼,基于jQuery遍歷簡(jiǎn)單實(shí)現(xiàn)菜單效果,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-09-09jQuery中的read和JavaScript中的onload函數(shù)的區(qū)別
這篇文章主要介紹了jQuery中的read和JavaScript中的onload函數(shù)的區(qū)別,這兩個(gè)函數(shù)在web編程中是最常用的,一定要搞清楚它們的區(qū)別,需要的朋友可以參考下2014-08-08