陣列方法
堆疊方法:堆疊是一種LIFO(last-in-first-out)後進先出的資料結構,也就是最新新增的項最早被移除。棧中項的插入(叫做推入)和移除(叫做彈出)只會發生在堆疊的頂端。
push()方法:可以接收任意數量的參數,把它們逐一加到陣列結尾,並傳回修改後陣列的長度。
pop()方法:從陣列結尾移除最後一項,減少陣列的length值,然後傳回移除的項目。
佇列方法:佇列是一種FIFO(first-in-first-out)先進先出的資料結構,佇列在清單的末端新增項,從清單的前端移除項目。
shift():移除數組中的第一個項目並返回該項目,同時數組的長度減1(結合使用shift()和push()可以模擬隊列)
unshift():在數組前端添加任意個項目並返回新數組長度(結合使用unshift()和pop()從相反方向模擬隊列)
[注意]IE7及以下unshift()方法返回的總是undefined
排序方法:
reverse():反轉數組的順序,返回經過排序後的陣列,
#reverse():按升序排列數組按升序排列數組sort方法會呼叫每個陣列項目的toString()方法,然後比較得到的字串排序,傳回經過排序之後的陣列
[注意]sort()方法可以接受一個比較函數作為參數,以便指定哪個值在哪個值的前面。比較函數接收兩個參數,如果第一個參數應該位於第二個參數之前則傳回一個負數,如果兩個參數相等則回傳0,如果第一個參數應該位於第二個參數之後則傳回一個正數
[比較函數] (使用:e.g. array1.sort(compare);)
function compare(value1,value2){ if(value1 < value2){ return -1; }else if(value1 > value2){ return 1; }else{ return 0; } }
對於數值類型或valueOf()方法會傳回數值類型的物件類型,比較函數可以簡化為:
function compare(value1,value2){ return value2 - value1; }
[tips]:常用以下方法來建立一個隨機數組
function compare(){ return Math.random() - 0.5; }
操作方法(切開、連接、插入、刪除、替換):
concat( ):基於目前數組中的所有項目創建一個新數組,先創建當前數組一個副本,然後將接收到的參數添加到這個副本的末尾,最後返回新構建的數組(concat()不影響原始數組)
[注意1]沒有給concat()方法傳遞參數時,它只是複製當前的陣列
[注意2]如果參數是一個或多個數組,則該方法會將這些數組中的每一項都會加到結果數組中
[注意3]如果傳遞的值不是數組,這些值就會被簡單地添加到結果數組的末尾
e.g. var numbers = [1,2]; console.log(numbers.concat());//[1,2] console.log(numbers.concat([5,4,3],[3,4,5],1,2));//[1,2,5,4,3,3,4,5,1,2];
slice ():基於目前數組中的一個或多個項目建立一個新數組,接受一個或兩個參數,即要傳回項目的起始和結束位置,最後返回新數組(slice()不影響原數組)
[注意1]沒有參數時,返回原始數組
[注意2]只有一個參數時,slice()方法會傳回從該參數指定位置開始到目前陣列結尾的所有項目
[注意3]兩個參數時,此方法傳回起始位置與結束位置之間的項,但不包含結束位置的項
[注意4]若參數為負數時,則以陣列長度加負數作為參數
[注意5]若結束位置小於開始位置,則傳回空數組
var numbers = [1,2,3,4,5]; console.log(numbers.slice());//[1,2,3,4,5] console.log(numbers.slice(2));//[3,4,5] console.log(numbers.slice(2,3));//[3] console.log(numbers.slice(-3));//-3+5=2 -> [3,4,5] console.log(numbers.slice(2,1));//[]
splice():原數組變成修改後的數組,而splice()傳回從原數組中刪除的項目所組成的數組,若無刪除項目則傳回空數組
[a]刪除:兩個參數為要刪除的第一項的位置、要刪除的項數
[b]插入:三個參數為起始位置、0(要刪除的基數)、要插入的項
[c]替換:三個參數為起始位置、要刪除的項目數、要插入的項目
[注意1]若第一個參數為負數時,則以陣列長度加負數為參數
[註2]若第二個參數為負數時,則以0作為參數
var numbers = [1,2,3,4,5]; console.log(numbers.splice(0,2),numbers);//[1,2] [3,4,5] var numbers = [1,2,3,4,5]; console.log(numbers.splice(1,0,11,12),numbers);//[] [1,11,12,2,3,4,5] var numbers = [1,2,3,4,5]; console.log(numbers.splice(1,3,11,12),numbers);//[2,3,4] [1,11,12,5] var numbers = [1,2,3,4,5]; console.log(numbers.splice(-4,3,11,12),numbers);//-4+5=1 -> [2,3,4] [1,11,12,5] var numbers = [1,2,3,4,5]; console.log(numbers.splice(-4,-3,11,12),numbers);//-4+5=1 -> [] [1,11,12,2,3,4,5]
位置方法(ECMAScript5):兩個參數:要尋找的項目、表示尋找起點位置的索引(可選)。傳回第一個滿足條件的查找項目在陣列中的位置,如果沒有找到則傳回-1(位置方法不會影響原始數組)
[注意]在比較時,使用全等運算子
indexOf()
lastIndexOf()
var person = {name: 'Nicholas'}; var people = [{name: 'Nicholas'}]; var morePeople = [person]; alert(people.indexOf(person));//-1,因为person和people[0]虽然值相同,但是是两个引用 alert(morePeople.indexOf(person));//0,因为person和morepeople[0]是同一个引用 alert(morePeople.indexOf({name: 'Nicholas'}));//-1,因为不是同一个引用
[tips]若傳回滿足條件的項目的所有索引值
function allIndexOf(array,value){ var result = []; var pos = array.indexOf(value); if(pos === -1){ return -1; } while(pos > -1){ result.push(pos); pos = array.indexOf(value,pos+1); } return result; } var array = [1,2,3,3,2,1]; console.log(allIndexOf(array,1));//[0,5]
迭代方法(ECMAScript5):兩個參數:要在每一項上執行的函數、執行該函數作用域物件-影響this的值(可選)。傳入這些方法中的函數會接收三個參數:數組項的值、該項在數組中的位置、數組物件本身(迭代方法不會影響原始數組)
every():對數組中的每一項運行給定函數,如果函數對每一項都傳回true,則傳回true
filter():對陣列中的每一項執行給定函數,則傳回該函數會傳回true的項組成的數組(常用於查詢符合條件的所有數組項)
forEach():對數組中的每一項運行給定函數,這個方法沒有返回值(相當於for循環)
map():对数组中的每一项运行给定函数,返回每次函数调用的结果组成的数组(常用于创建包含项与另一个数组一一对应的数组)
some():对数组中的每一项运行给定函数,如果该函数对任一项返回true,则返回true
var numbers = [1,2,3,4,5,6,7,8,9,0]; var sum = 0; var everyResult = numbers.every(function(item,index,array){ return (item>2); }); var filterResult = numbers.filter(function(item,index,array){ return (item>2) }); var forEachResult = numbers.forEach(function(item,index,array){ sum += item; return (item>2) }); var mapResult = numbers.map(function(item,index,array){ return (item*2) }); var som = numbers.some(function(item,index,array){ return (item>2) }); console.log(everyResult);//false console.log(filterResult);//[3,4,5,6,7,8,9] console.log(forEachResult,sum);//undefined 45 console.log(mapResult);//[2,4,6,8,10,12,14,16,18,0] console.log(someResult);//true [tips] function logArray(value,index,array){ console.log(value); } [2,5,,,,,9].forEach(logArray)//2 5 9
归并方法(ECMAScript5):迭代数组的所有项,构建一个最终返回的值。接收两个参数:一个在每一项上调用的函数、作为归并基础的初始值(可选)。传给reduce()和reduceRight()的函数接受4个参数:前一个值、当前值、项的索引和数组对象。这个函数返回的任何值都会作为第一个参数自动传给下一项。第一次迭代发生在数组的第二项上。因此,第一个参数是数组第一项,第二个参数是数组第二项(归并方法不会影响原数组)
reduce()
reduceRight()
var sum = values.reduce(function(prev,cur,index,array){ return prev+cur; }) alert(sum);//15
以上是javascript中的各種數組方法實例匯總的詳細內容。更多資訊請關注PHP中文網其他相關文章!