您好,登錄后才能下訂單哦!
引用類型分為Object類型(所謂的對象),Array類型(本文談的數(shù)組),F(xiàn)unction類型等。
那么,數(shù)組是干啥的呢?在我看來,它是用來保存數(shù)據(jù)的。
一、聲明一個數(shù)組:
1、構造函數(shù) var colors=new Array();簡寫的話可以省略new,即var colors=Array();
2、數(shù)組字面量 var colors=["black","green","pink"];
二、讀取和設置數(shù)組的值:
讀?。篶olors[x];參數(shù)x為0~colors.length-1;
設置的話直接給colors[x]=進行賦值就好,這樣會覆蓋之前的數(shù)值哦;
三、在這里簡單說說length的用法:
colors.length獲取數(shù)組的長度,也可以說是數(shù)組有幾項,如果說一個數(shù)組有7項,但是你寫入了colors.length=2,那么就會刪除后面的5項;
利用length屬性也可以為數(shù)組最后添加數(shù)據(jù):colors[colors.length]=進行賦值;
四、數(shù)組中的操作:
方法 | 作用 | 返回值 |
Array.push(x,y,z) | 把xyz添加到數(shù)組末尾 | 新數(shù)組長度 |
Array.pop() | 移除數(shù)組最后一項 | 移除的最后一項 |
Array.shift() | 移除數(shù)組第一項 | 移除的第一項 |
Array.unshift(a,b,c) | 在數(shù)組前端添加a,b,c | 新數(shù)組長度 |
Array.reverse() | 反轉數(shù)組 | 反轉后的新數(shù)組 |
Array.sort() | 對數(shù)組中每一項的字符串進行升序排列 | 重新排序后的數(shù)組 |
Array.concat(a,b,c) | 連接數(shù)組 | 返回連接好的新數(shù)組 |
Array.slice(1,n) | 截取數(shù)組,從1到n,1和n為索引值 | 返回截取的數(shù)組(在這里返回從1開始,到n之前結束) |
Array.indexOf(a,start) | 查找a的所在的位置,從start開始 | 返回a所在的索引值,如果沒有查找到則返回-1 |
Array.lastIndexOf(a,atart) | 與indexOf相反,lastIndexOf從末尾開始查找 | 返回a所在的索引值,如果沒有查找到則返回-1 |
splice()方法單拿出來說說。為什么單拿出來?因為牛逼;
1.刪除。接受兩個參數(shù):要刪除第一項的位置和要刪除的項數(shù);
例:splice(1,2),就是要刪除數(shù)組種的2,3項;
2.插入。接受三個參數(shù):起始位置,0,要插入的項。
例:splice(2,0,"red","green"),會在數(shù)組索引值為2的位置插入red和green。
3.替換。接受三個參數(shù):起始位置,要刪除的項數(shù),要插入的項。
例:splice(2,1,"red","green"),刪除索引值為2這一項,添加red和green。
tips:sort()用法實例:按升序排列數(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ù)組中的每一項是否滿足條件,如果每一項都返回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ù)組中的每一項是否滿足條件,如果有一項都返回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():
該方法會返回結果為true的項組成的數(shù)組;
3.map():
var result=numbers.map(function(item,index,array){ return item*2; })
返回數(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);
在上個例子中,reduce()接受四個參數(shù),第一個參數(shù)是數(shù)組的第一項,第二個參數(shù)是數(shù)組的第二項;
第一次執(zhí)行函數(shù),prev是1,cur是2,第二次執(zhí)行,prev是3(1+2的結果),cur是3。
Array.reduceRight()。和reduce類似。只不過從數(shù)組右側開始。
以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持億速云!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。