JavaScript中數(shù)組的22種方法必學(xué)(推薦)
來源:易賢網(wǎng) 閱讀:836 次 日期:2016-07-29 16:57:11
溫馨提示:易賢網(wǎng)小編為您整理了“JavaScript中數(shù)組的22種方法必學(xué)(推薦)”,方便廣大網(wǎng)友查閱!

這篇文章主要介紹了JavaScript中數(shù)組的22種方法必學(xué)(推薦)的相關(guān)資料,需要的朋友可以參考下

前面的話

數(shù)組總共有22種方法,本文將其分為對象繼承方法、數(shù)組轉(zhuǎn)換方法、棧和隊列方法、數(shù)組排序方法、數(shù)組拼接方法、創(chuàng)建子數(shù)組方法、數(shù)組刪改方法、數(shù)組位置方法、數(shù)組歸并方法和數(shù)組迭代方法共10類來進行詳細介紹

對象繼承方法

數(shù)組是一種特殊的對象,繼承了對象Object的toString()、toLocaleString()和valueOf()方法

【toString()】

toString()方法返回由數(shù)組中每個值的字符串形式拼接而成的一個以逗號分隔的字符串

[注意]該方法的返回值與不使用任何參數(shù)調(diào)用join()方法返回的字符串相同

[1,2,3].toString();//'1,2,3'

['a','b','c'].toString();//'a,b,c'

[1,[2,'c']].toString();//'1,2,c'

由于alert()要接收字符串參數(shù),它會在后臺調(diào)用toString()方法,會得到與toString()方法相同的結(jié)果

alert([1,2,3]);//'1,2,3'

【toLocaleString()】

toLocaleString()是toString()方法的本地化版本,它經(jīng)常也會返回與toString()方法相同的值,但也不總是如此。因為,它調(diào)用元素的是toLocaleString()方法將每個數(shù)組元素轉(zhuǎn)化為字符串

var person1 = {

toLocaleString: function(){

return 'Nikolaos';

},

toString: function(){

return 'Nicholas';

}

};

var person2 = {

toLocaleString: function(){

return 'Grigorios';

},

toString: function(){

return 'Greg';

}

};

var people = [person1,person2];

console.log(people.toString());//'Nicholas,Greg'

console.log(people.toLocaleString());//'Nikolaos,Grigorios'

如果數(shù)組中的某一項的值是null或者undefined,則該值在toLocaleString()和toString()方法返回的結(jié)果中以空字符串表示

var colors = [1,undefined,2,null,3];

console.log(colors.toString());//'1,,2,,3'

console.log(colors.toLocaleString());//'1,,2,,3'

【valueOf()】

valueOf()方法返回數(shù)組對象本身

var a = [1, 2, 3];

console.log(a.valueOf());// [1, 2, 3]

console.log(a.valueOf() instanceof Array);//true

數(shù)組轉(zhuǎn)換方法

【join()】

Array.join()方法是String.split()方法的逆向操作,后者是將字符串分割成若干塊來創(chuàng)建一個數(shù)組

數(shù)組繼承的toLocaleString()和toString()方法,在默認情況下都會以逗號分隔的字符形式返回數(shù)組項;而join()方法可以使用不同的分隔符來構(gòu)建這個字符串,join()方法只接收一個參數(shù),用作分隔符的字符串,然后返回包含所有數(shù)組項的字符串

如果不給join()方法傳入任何值,則使用逗號作為分隔符

var a = [1,2,3];

console.log(a.join());//'1,2,3'

console.log(a.join(' '));//'1 2 3'

console.log(a.join(''));//'123'

var b = new Array(10);

b.join('-');//'---------',9個連字符組成的字符串

若join()方法的參數(shù)是undefined,標準瀏覽器以逗號為分隔符返回字符串,而IE7-瀏覽器以'undefined'為分隔符返回字符串

//標準瀏覽器為'1,2,3';IE7-瀏覽器為'1undefined2undefined3'

var a = [1,2,3];

console.log(a.join(undefined));

如果數(shù)組中的某一項的值是null或者undefined,則該值在join()方法返回的結(jié)果中以空字符串表示

var colors = [1,undefined,2,null,3];

console.log(colors.join());//'1,,2,,3'

該方法也可以用于類數(shù)組對象上

console.log(Array.prototype.join.call('hello', '-'));// "h-e-l-l-o"

var obj = { 0: 'a', 1: 'b', length: 2 };

console.log(Array.prototype.join.call(obj, '-'));// 'a-b'

[注意]若對象沒有l(wèi)ength屬性,就不是類數(shù)組,也就不能調(diào)用數(shù)組的方法

var obj = { 0: 'a', 1: 'b' };

console.log(typeof Array.prototype.join.call(obj, '-'));//''

棧和隊列方法

push()和pop()方法允許將數(shù)組當(dāng)作棧來使用。unshift()和shift()方法的行為非常類似于push()和pop(),不一樣的是前者是在數(shù)組的頭部而非尾部進行元素的插入和刪除操作

棧是一種LIFO(Last-First-Out,后進先出)的數(shù)據(jù)結(jié)構(gòu),也就是最新添加的項最早被移除。而棧中項的插入(叫做推入)和移除(叫做彈出),只發(fā)生在一個位置——棧的頂部。javascript為數(shù)組專門提供了push()和pop()方法,以便實現(xiàn)類似棧的行為

隊列數(shù)據(jù)結(jié)構(gòu)的訪問規(guī)則是FIFO(first-in-first-out,先進先出)。隊列在列表的末端添加項,從列表的前端移除項。結(jié)合使用shift()和push()方法,可以像使用隊列一樣使用數(shù)組

【push()】

push()方法可以接收任意數(shù)量的參數(shù),把它們逐個添加到數(shù)組末尾,并返回修改后數(shù)組的長度。所以,該數(shù)組會改變原數(shù)組

var a = [];

console.log(a,a.push(1));//[1] 1

console.log(a,a.push('a'));//[1,'a'] 2

console.log(a,a.push(true, {}));//[1,'a',true,{}] 4

console.log(a,a.push([5,6]));//[1,'a',true,{},[5,6]] 5

如果需要合并兩個數(shù)組,可以使用apply方法

var a = [1, 2, 3];

var b = [4, 5, 6];

console.log(a,Array.prototype.push.apply(a, b));//[1,2,3,4,5,6] 6

[注意]如果使用call方法,則會把數(shù)組b整體看成一個參數(shù)

var a = [1, 2, 3];

var b = [4, 5, 6];

console.log(a,Array.prototype.push.call(a, b));//[1,2,3,[4,5,6]] 4

push()方法也可以向?qū)ο笾刑砑釉?,添加后的對象變成類?shù)組對象,即新加入元素的鍵對應(yīng)數(shù)組的索引,并且對象有一個length屬性

var obj = {a: 1};

console.log(obj,[].push.call(obj, 2));// {a:1, 0:2, length: 1}

console.log(obj,[].push.call(obj, [3]));// {a:1, 0:2, 1:[3], length: 2}

【pop()】

pop()方法從數(shù)組末尾移除最后一項,減少數(shù)組的length值,然后返回移除的項。所以,該數(shù)組會改變原數(shù)組

var a = ['a', 'b', 'c'];

console.log(a,a.pop()); // ['a', 'b'] 'c'

對空數(shù)組使用pop()方法,不會報錯,而是返回undefined

var a = [];

console.log(a,a.pop()); // [] undefined

【shift()】

shift()方法移除數(shù)組中的第一個項并返回該項,同時數(shù)組的長度減1。所以,該數(shù)組會改變原數(shù)組

var a = ['a', 'b', 'c'];

console.log(a,a.shift());//['b', 'c'] 'a'

對空數(shù)組使用shift()方法,不會報錯,而是返回undefined

var a = [];

console.log(a,a.shift());// [] undefined

【unshift()】

unshift()方法在數(shù)組前端添加任意個項并返回新數(shù)組長度。所以,該數(shù)組會改變原數(shù)組

var a = ['a', 'b', 'c'];

console.log(a,a.unshift('x')); //['x', 'a', 'b', 'c'] 4

當(dāng)使用多個參數(shù)調(diào)用unshift()時,參數(shù)是一次性插入的而非一次一個地插入。這意味著最終的數(shù)組中插入的元素的順序和它們在參數(shù)列表中的順序一致

var a = ['a', 'b', 'c'];

console.log(a,a.unshift('x','y','z')); //['x','y','z','a', 'b', 'c'] 6

[注意]在IE7-瀏覽器中,unshift()方法返回的總是undefined

//標準瀏覽器下,返回[1] 1;而IE7-瀏覽器下,返回[1] undefined

var a = [];

console.log(a,a.unshift(1));

數(shù)組排序方法

數(shù)組中存在兩個可以直接用來重排序的方法: reverse()和sort() 

【reverse()】

reverse()方法用于反轉(zhuǎn)數(shù)組的順序,返回經(jīng)過排序之后的數(shù)組;而原數(shù)組順序也發(fā)生改變

var array = [1,2,4,3,5];

console.log(array,array.reverse());//[5,3,4,2,1] [5,3,4,2,1]

var array = ['str',true,3];

console.log(array,array.reverse());//[3,true,'str'] [3,true,'str']

【sort()】

默認情況下,sort()方法按字符串升序排列數(shù)組項,sort方法會調(diào)用每個數(shù)組項的toString()方法,然后比較得到的字符串排序,返回經(jīng)過排序之后的數(shù)組,而原數(shù)組順序也發(fā)生改變

var array = [1,2,4,3,5];

console.log(array,array.sort());//[1,2,3,4,5] [1,2,3,4,5]

var array = ['3str',3,2,'2'];

console.log(array,array.sort());//[2, "2", 3, "3str"] [2, "2", 3, "3str"]

var array = [1,5,10,50];

console.log(array,array.sort());//[1, 10, 5, 50] [1, 10, 5, 50]

如果數(shù)組包含undefined元素,它們會被排到數(shù)組的尾部

var array = ['3',3,undefined,2,'2'];

console.log(array,array.sort());//["2", 2, "3", 3, undefined] ["2", 2, "3", 3, undefined]

sort()方法可以接受一個比較函數(shù)作為參數(shù),以便指定哪個值在哪個值的前面。比較函數(shù)接收兩個參數(shù),如果第一個參數(shù)應(yīng)該位于第二個參數(shù)之前則返回一個負數(shù),如果兩個參數(shù)相等則返回0,如果第一個參數(shù)應(yīng)該位于第二個參數(shù)之后則返回一個正數(shù)

function compare(value1,value2){

if(value1 < value2){

return -1;

}else if(value1 > value2){

return 1;

}else{

return 0;

}

}

var array = ['5px',50,1,10];

//當(dāng)數(shù)字與字符串比較大小時,字符串'5px'會被轉(zhuǎn)換成NaN,這樣結(jié)果就是false

console.log(array.sort(compare));//["5px",1, 10, 50]

對于數(shù)值類型或valueOf()方法會返回數(shù)值類型的對象類型,比較函數(shù)可以簡化

function compare(value1,value2){

return value1 - value2;

}

var array = ['5px',50,1,10];

console.log(array.sort(compare));//["5px",1,10,50]

var array = [5,50,1,10];

console.log(array.sort(compare));//[1,5,10,50]

如果對一個字符串?dāng)?shù)組執(zhí)行不區(qū)分大小寫的字母表排序,比較函數(shù)首先將參數(shù)轉(zhuǎn)化為小寫字符串再開始比較

a = ['ant','Bug','cat','Dog'];

a.sort();//['Bug','Dog','ant','cat'];

a.sort(function(s,t){

var a = s.toLowerCase();

var b = t.toLowerCase();

if(a < b)return -1;

if(a > b)return 1;

return 0;

});//['ant','bug','cat','dog']

【tips】使用sort()方法創(chuàng)建一個隨機數(shù)組

function compare(){

return Math.random() - 0.5;

}

var array = [1,2,3,4,5];

console.log(array.sort(compare));//[2,1,5,4,3]

數(shù)組拼接方法

【concat()】

concat()方法基于當(dāng)前數(shù)組中的所有項創(chuàng)建一個新數(shù)組,先創(chuàng)建當(dāng)前數(shù)組一個副本,然后將接收到的參數(shù)添加到這個副本的末尾,最后返回新構(gòu)建的數(shù)組。所以concat()不影響原數(shù)組

如果不給concat()方法傳遞參數(shù)時,它只是復(fù)制當(dāng)前的數(shù)組;如果參數(shù)是一個或多個數(shù)組,則該方法會將這些數(shù)組中的每一項都添加到結(jié)果數(shù)組中;如果傳遞的值不是數(shù)組,這些值就會被簡單地添加到結(jié)果數(shù)組的末尾

var numbers = [1,2];

console.log(numbers,numbers.concat(3,4));//[1,2] [1,2,3,4]

console.log(numbers,numbers.concat([5,4,3],[3,4,5],1,2));//[1,2] [1,2,5,4,3,3,4,5,1,2]

console.log(numbers,numbers.concat(4,[5,[6,7]]));//[1,2] [1,2,4,5,[6,7]]

如果不提供參數(shù),concat()方法返回當(dāng)前數(shù)組的一個淺拷貝。所謂“淺拷貝”,指的是如果數(shù)組成員包括復(fù)合類型的值(比如對象),則新數(shù)組拷貝的是該值的引用

//該方法實際只復(fù)制了數(shù)組的第一維,數(shù)組第一維存放的是第二維的引用,而第二維才是實際存放他們的內(nèi)容

var numbers = [1,2];

var newNumbers = numbers.concat();

console.log(numbers,newNumbers);//[1,2] [1,2]

numbers[0] = 0;

console.log(numbers,newNumbers);//[0,2] [1,2]

var numbers = [[1,2]];

var newNumbers = numbers.concat();

console.log(numbers,newNumbers);//[[1,2]] [[1,2]]

numbers[0][0] = 0;

console.log(numbers,newNumbers);//[[0,2]] [[0,2]]

concat()方法也可以用于將對象合并為數(shù)組,但是必須借助call()方法

var newArray = Array.prototype.concat.call({ a: 1 }, { b: 2 })

console.log(newArray);// [{ a: 1 }, { b: 2 }]

console.log(newArray[0].a);//1

創(chuàng)建子數(shù)組方法

【slice()】

slice()方法基于當(dāng)前數(shù)組中的一個或多個項創(chuàng)建一個新數(shù)組,接受一個或兩個參數(shù),即要返回項的起始和結(jié)束位置,最后返回新數(shù)組,所以slice()不影響原數(shù)組

slice(start,end)方法需要兩個參數(shù)start和end,返回這個數(shù)組中從start位置到(但不包含)end位置的一個子數(shù)組;如果end為undefined或不存在,則返回從start位置到數(shù)組結(jié)尾的所有項

如果start是負數(shù),則start = max(length + start,0)

如果end是負數(shù),則end = max(length + end,0)

start和end無法交換位置

如果沒有參數(shù),則返回原數(shù)組

var numbers = [1,2,3,4,5];

console.log(numbers.slice(2));//[3,4,5]

console.log(numbers.slice(2,undefined));//[3,4,5]

console.log(numbers.slice(2,3));//[3]

console.log(numbers.slice(2,1));//[]

console.log(numbers.slice(-3));//-3+5=2 -> [3,4,5]

console.log(numbers.slice(-8));//max(5 + -8,0)=0 -> [1,2,3,4,5]

console.log(numbers.slice(0,-3));//-3+5=2 -> [1,2]

console.log(numbers.slice(-2,-1));//-2+5=3;-1+5=4; -> [4]

如果不提供參數(shù),slice()方法返回當(dāng)前數(shù)組的一個淺拷貝

//該方法實際只復(fù)制了數(shù)組的第一維,數(shù)組第一維存放的是第二維的引用,而第二維才是實際存放他們的內(nèi)容

var numbers = [1,2];

var newNumbers = numbers.slice();

console.log(numbers,newNumbers);//[1,2] [1,2]

numbers[0] = 0;

console.log(numbers,newNumbers);//[0,2] [1,2]

var numbers = [[1,2]];

var newNumbers = numbers.slice();

console.log(numbers,newNumbers);//[[1,2]] [[1,2]]

numbers[0][0] = 0;

console.log(numbers,newNumbers);//[[0,2]] [[0,2]]

slice()方法涉及到Number()轉(zhuǎn)型函數(shù)的隱式類型轉(zhuǎn)換,當(dāng)start被轉(zhuǎn)換為NaN時,相當(dāng)于start = 0;當(dāng)end被轉(zhuǎn)換為NaN時(end為undefined除外),則輸出空數(shù)組

var numbers = [1,2,3,4,5];

console.log(numbers.slice(NaN));//[1,2,3,4,5]

console.log(numbers.slice(0,NaN));//[]

console.log(numbers.slice(true,[3]));//[2,3]

console.log(numbers.slice(null,undefined));//[1,2,3,4,5]

console.log(numbers.slice({}));//[1,2,3,4,5]

console.log(numbers.slice('2',[5]));//[3,4,5]

可以使用slice()方法將類數(shù)組對象變成真正的數(shù)組

var arr = Array.prototype.slice.call(arrayLike);

Array.prototype.slice.call({ 0: 'a', 1: 'b', length: 2 })// ['a', 'b']

Array.prototype.slice.call(document.querySelectorAll("div"));

Array.prototype.slice.call(arguments);

數(shù)組刪改方法

【splice()】

splice()和slice()擁有非常相似的名字,但它們的功能卻有本質(zhì)的區(qū)別。splice()方法用于刪除原數(shù)組的一部分成員,并可以在被刪除的位置添加入新的數(shù)組成員,該方法會改變原數(shù)組

splice()返回一個由刪除元素組成的數(shù)組,或者如果沒有刪除元素就返回一個空數(shù)組

splice()的第一個參數(shù)start指定了插入或刪除的起始位置。如果start是負數(shù),則start = max(length + start,0);如果start是NaN,則相當(dāng)于start = 0

如果只提供一個元素,相當(dāng)于將原數(shù)組在指定位置拆分成兩個數(shù)組

var a = [1,2,3,4,5,6,7,8];

console.log(a,a.splice());// [1,2,3,4,5,6,7,8] []

var a = [1,2,3,4,5,6,7,8];

console.log(a,a.splice(4));// [1,2,3,4] [5,6,7,8]

var a = [1,2,3,4,5,6,7,8];

console.log(a,a.splice(-4));//-4+8=4; [1,2,3,4] [5,6,7,8]

var a = [1,2,3,4,5,6,7,8];

console.log(a,a.splice(-9));//max(-9+8,0)=0 [] [1,2,3,4,5,6,7,8]

var a = [1,2,3,4,5,6,7,8];

console.log(a,a.splice(NaN));//[] [1,2,3,4,5,6,7,8]

第二個參數(shù)number指定了應(yīng)該從數(shù)組中刪除的元素的個數(shù)。如果省略第二個參數(shù),從起始點開始到數(shù)組結(jié)尾的所有元素都將被刪除。如果number是負數(shù)或NaN或undefined,則number=0,因此不刪除元素

var a = [1,2,3,4,5,6,7,8];

console.log(a,a.splice(0,2));// [3,4,5,6,7,8] [1,2]

var a = [1,2,3,4,5,6,7,8];

console.log(a,a.splice(10,2));// [1,2,3,4,5,6,7,8] []

var a = [1,2,3,4,5,6,7,8];

console.log(a,a.splice(1,100));// [1] [2,3,4,5,6,7,8]

var a = [1,2,3,4,5,6,7,8];

console.log(a,a.splice(1,-5));//[1,2,3,4,5,6,7,8] []

var a = [1,2,3,4,5,6,7,8];

console.log(a,a.splice(1,NaN));//[1,2,3,4,5,6,7,8] []

var a = [1,2,3,4,5,6,7,8];

console.log(a,a.splice(1,undefined));//[1,2,3,4,5,6,7,8] []

如果后面還有更多的參數(shù),則表示這些就是要被插入數(shù)組的新元素

var a = [1,2,3,4,5];

console.log(a,a.splice(2,0,'a','b'));//[1,2,'a','b',3,4,5] []

console.log(a,a.splice(2,2,[1,2],3));//[1,2,[1,2],3,3,4,5] ['a','b']

數(shù)組位置方法

ES5為數(shù)組實例添加了兩個位置方法:indexOf()、lastIndexOf()

【indexOf()】

indexOf(search,start)方法接收search和start兩個參數(shù),返回search首次出現(xiàn)的位置,如果沒有找到則返回-1

search參數(shù)表示要搜索的項;使用嚴格相等運算符(===)進行比較

var arr = [1,2,3,'1','2','3'];

console.log(arr.indexOf('2'));//4

console.log(arr.indexOf(3));//2

console.log(arr.indexOf(0));//-1

start參數(shù)表示該搜索的開始位置,該方法會隱式調(diào)用Number()轉(zhuǎn)型函數(shù),將start非數(shù)字值(undefined除外)轉(zhuǎn)換為數(shù)字。若忽略該參數(shù)或該參數(shù)為undefined或NaN時,start = 0

var arr = ['a','b','c','d','e','a','b'];

console.log(arr.indexOf('a',undefined));//0

console.log(arr.indexOf('a',NaN));//0

console.log(arr.indexOf('a',1));//5

console.log(arr.indexOf('a',true));//5

console.log(arr.indexOf('a',-1));//max(0,-1+7)=6; -1

console.log(arr.indexOf('a',-5));//max(0,-5+7)=2; 5

console.log(arr.indexOf('a',-50));//max(0,-50+7)=0; 0 

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,因為不是同一個引用

indexOf()方法兼容寫法

if (typeof Array.prototype.indexOf != "function") {

Array.prototype.indexOf = function (searchElement, fromIndex) {

var index = -1;

fromIndex = fromIndex * 1 || 0;

for (var k = 0, length = this.length; k < length; k++) {

if (k >= fromIndex && this[k] === searchElement) {

index = k;

break;

}

}

return index;

};

}

【lastIndexOf()】

與indexOf()不同,lastIndexOf()從右向左查找

lastIndexOf(search,start)方法接收search和start兩個參數(shù),返回search第一次出現(xiàn)的位置,如果沒有找到則返回-1

search參數(shù)表示要搜索的項;使用嚴格相等運算符(===)進行比較

var arr = [1,2,3,'1','2','3'];

console.log(arr.lastIndexOf('2'));//4

console.log(arr.lastIndexOf(3));//2

console.log(arr.lastIndexOf(0));//-1

start表示該搜索的開始位置,該方法會隱式調(diào)用Number()轉(zhuǎn)型函數(shù),將start非數(shù)字值(undefined除外)轉(zhuǎn)換為數(shù)。若忽略該參數(shù)或該參數(shù)為undefined或NaN時,start = 0

與字符串的lastIndexOf()方法不同,當(dāng)search方法為負數(shù)時,search = max(0,length+search)

var arr = ['a','b','c','d','e','a','b'];

console.log(arr.lastIndexOf('b'));//6

console.log(arr.lastIndexOf('b',undefined));//-1

console.log(arr.lastIndexOf('a',undefined));//0

console.log(arr.lastIndexOf('b',NaN));//-1

console.log(arr.lastIndexOf('b',1));//1

console.log(arr.lastIndexOf('b',-1));//max(0,-1+7)=6; 6

console.log(arr.lastIndexOf('b',-5));//max(0,-5+7)=2; 1

console.log(arr.lastIndexOf('b',-50));//max(0,-50+7)=0; -1

【tips】返回滿足條件的項的所有索引值

可以通過循環(huán)調(diào)用indexOf()或lastIndexOf()來找到所有匹配的項

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]

lastIndexOf()方法兼容寫法

if (typeof Array.prototype.lastIndexOf != "function") {

Array.prototype.lastIndexOf = function (searchElement, fromIndex) {

var index = -1, length = this.length;

fromIndex = fromIndex * 1 || length - 1;

for (var k = length - 1; k > -1; k-=1) {

if (k <= fromIndex && this[k] === searchElement) {

index = k;

break;

}

}

return index;

};

}

數(shù)組歸并方法

數(shù)組歸并方法包括reduce()和reduceRight()方法兩種,它們使用指定的函數(shù)將數(shù)組元素進行組合,生成單個值。這在函數(shù)式編程中是常見的操作,也可以稱為“注入”和“折疊”

【reduce()】

reduce()方法需要兩個參數(shù)。第一個是執(zhí)行化簡操作的函數(shù)。化簡函數(shù)的任務(wù)就是用某種方法把兩個值組合或化簡為一個值,并返回化簡后的值

化簡函數(shù)接受四個參數(shù),分別是:

【1】初始變量,默認為數(shù)組的第一個元素值。函數(shù)第一次執(zhí)行后的返回值作為函數(shù)第二次執(zhí)行的初始變量,依次類推

【2】當(dāng)前變量,如果指定了第二個參數(shù),則該變量為數(shù)組的第一個元素的值,否則,為第二個元素的值

【3】當(dāng)前變量對應(yīng)的元素在數(shù)組中的索引(從0開始)

【4】原數(shù)組對象

化簡函數(shù)的這四個參數(shù)之中,只有前兩個是必須的,后兩個則是可選的

values.reduce(function(prev, cur, index, array){

//todo

});

reduce()方法第二個(可選)的參數(shù)是一個傳遞給函數(shù)的初始值

var a = [1,2,3,4,5];

var sum = a.reduce(function(x,y){return x+y},0);//數(shù)組求和

var product = a.reduce(function(x,y){return x*y},1);//數(shù)組求積

var max = a.reduce(function(x,y){return (x>y)?x:y;});//求最大值

[1, 2, 3, 4, 5].reduce(function(prev, cur){

console.log(prev, cur)

return prev+ cur;

});

// 1 2

// 3 3

// 6 4

// 10 5

//最后結(jié)果:15

[1, 2, 3, 4, 5].reduce(function(prev, cur){

console.log(prev, cur);

return prev + cur;

},0);

// 0 1

// 1 2

// 3 3

// 6 4

// 10 5

//最后結(jié)果:15

[注意]reduce()方法的返回結(jié)果類型和傳入的初始值相同

[1, 2, 3, 4, 5].reduce(function(prev, cur){

console.log(prev.sum, cur);

prev.sum = prev.sum + cur;

return prev;

},{sum:0});

//0 1

//1 2

//3 3

//6 4

//10 5

//Object {sum: 15}

利用reduce()方法,可以寫一個數(shù)組求和的sum方法

Array.prototype.sum = function (){

return this.reduce(function (prev, cur){

return prev + cur;

})

};

[3,4,5,6,10].sum();// 28

由于reduce方法依次處理每個元素,所以實際上還可以用它來搜索某個元素。比如,找出長度最長的數(shù)組元素

function findLongest(entries) {

return entries.reduce(function (prev, cur) {

return cur.length > prev.length ? cur : prev;

}, '');

}

console.log(findLongest([1,2,3,'ab',4,'bcd',5,6785,4]));//'bcd'

可以利用reduce()方法,實現(xiàn)二維數(shù)組的扁平化

var matrix = [

[1, 2],

[3, 4],

[5, 6]

];

// 二維數(shù)組扁平化

var flatten = matrix.reduce(function (prev, cur) {

return prev.concat(cur);

});

console.log(flatten); // [1, 2, 3, 4, 5, 6]

在空數(shù)組上,不帶初始值參數(shù)調(diào)用reduce()將導(dǎo)致類型錯誤異常。如果調(diào)用它的時候只有一個值——數(shù)組只有一個元素并且沒有指定初始值,或者有一個空數(shù)組并且指定一個初始值——reduce()只是簡單地返回那個值而不會調(diào)用化簡函數(shù)

var arr = [];

arr.reduce(function(){});//Uncaught TypeError: Reduce of empty array with no initial value

var arr = [];

arr.reduce(function(){},1);//1

reduce()方法兼容寫法

if (typeof Array.prototype.reduce != "function") {

Array.prototype.reduce = function (callback, initialValue ) {

var previous = initialValue, k = 0, length = this.length;

if (typeof initialValue === "undefined") {

previous = this[0];

k = 1;

}

if (typeof callback === "function") {

for (k; k < length; k++) {

this.hasOwnProperty(k) && (previous = callback(previous, this[k], k, this));

}

}

return previous;

};

}

【reduceRight()】

reduceRight()的工作原理和reduce()一樣,不同的是它按照數(shù)組索引從高到低(從右到左)處理數(shù)組,而不是從低到高

var values = [1,2,3,4,5];

var sum = values.reduceRight(function(prev, cur, index, array){

console.log(prev,cur);

return prev + cur;

});

console.log(sum);

//5 4

//9 3

//12 2

//14 1

//15

reduceRight()方法兼容寫法

if (typeof Array.prototype.reduceRight != "function") {

Array.prototype.reduceRight = function (callback, initialValue ) {

var length = this.length, k = length - 1, previous = initialValue;

if (typeof initialValue === "undefined") {

previous = this[length - 1];

k--;

}

if (typeof callback === "function") {

for (k; k > -1; k-=1) { 

this.hasOwnProperty(k) && (previous = callback(previous, this[k], k, this));

}

}

return previous;

};

}

數(shù)組迭代方法

ECMAScript5為數(shù)組定義了5個迭代方法。每個方法都接收兩個參數(shù):要在每一項上運行的函數(shù)和(可選的)運行該函數(shù)的作用域?qū)ο蟆绊憈his的值。傳入這些方法中的函數(shù)會接收三個參數(shù):數(shù)組項的值、該項在數(shù)組中的位置和數(shù)組對象本身。根據(jù)使用的方法不同,這個函數(shù)執(zhí)行后的返回值可能會也可能不會影響訪問的返回值

function(item,index,array){

//todo

}

【map()】

map()方法對數(shù)組的每一項運行給定函數(shù),返回每次函數(shù)調(diào)用的結(jié)果組成的數(shù)組

//f是array的每一個元素調(diào)用的函數(shù)。它的返回值成為返回數(shù)組的元素;o是f調(diào)用時的可選this值

array.map(f,o); 

[1,2,3].map(function(item,index,arr){return item*item});//[1,4,9]

[1,2,3].map(function(item,index,arr){return item*index});//[0,2,6]

map()方法還可以接受第二個參數(shù),表示回調(diào)函數(shù)執(zhí)行時this所指向的對象

var arr = ['a','b','c'];

[1,2].map(function(item,index,arr){return this[item]},arr);//['b','c']

在實際使用的時候,可以利用map()方法方便獲得對象數(shù)組中的特定屬性值

var users = [{name:'t1',email:'t1@qq.com'},{name:'t2',email:'t2@qq.com'},{name:'t3',email:'t3@qq.com'}];

console.log(users.map(function(item,index,arr){return item.email}));//["t1@qq.com", "t2@qq.com", "t3@qq.com"]

map()方法還可以用于類數(shù)組對象

Array.prototype.map.call('abc',function(item,index,arr){return item.toUpperCase()});//["A", "B", "C"]

對于稀疏數(shù)組,map()方法不會在實際上不存在元素的序號上調(diào)用函數(shù)

var a = [1,,3];

console.log(a.map(function(item,index,arr){return item*2;}));//[2, 2: 6]

map()方法兼容寫法

if (typeof Array.prototype.map != "function") {

Array.prototype.map = function (fn, context) {

var arr = [];

if (typeof fn === "function") {

for (var k = 0, length = this.length; k < length; k++) { 

arr.push(fn.call(context, this[k], k, this));

}

}

return arr;

};

}

【forEach()】

forEach()方法對數(shù)組中的每一項運行給定函數(shù),這個方法沒有返回值。本質(zhì)上與for循環(huán)迭代數(shù)組一樣。如果需要有返回值,一般使用map方法

[1,2,3,4].forEach(function(item,index,arr){

console.log(item)

});

//1

//2

//3

//4

類似于如下的for循環(huán)

var array = [1, 2, 3, 4];

for (var k = 0, length = array.length; k < length; k++) {

console.log(array[k]);

}

使用forEach()方法實現(xiàn)簡單的加法

var sum = 0;

[1, 2, 3, 4].forEach(function (item, index, array) {

sum += item;

});

console.log(sum);//10

forEach()方法除了接受一個必須的回調(diào)函數(shù)參數(shù),第二個參數(shù)還可以接受一個可選的上下文參數(shù)(改變回調(diào)函數(shù)里面的this指向)

var out = [];

[1, 2, 3].forEach(function(elem){

this.push(elem * elem);

}, out);

console.log(out);// [1, 4, 9]

第二個參數(shù)對于多層this非常有用,因為多層this通常指向是不一致的,可以使用forEach()方法的第二個參數(shù)固定this

var obj = {

name: '張三',

times: [1, 2, 3],

print: function () {

//該this指向obj

console.log(this);

this.times.forEach(function (n) {

//該this指向window

console.log(this);

});

}

};

obj.print();

var obj = {

name: '張三',

times: [1, 2, 3],

print: function () {

//該this指向obj

console.log(this);

this.times.forEach(function (n) {

//該this同樣指向obj

console.log(this);

},this);

}

};

obj.print();

forEach()循環(huán)可以用于類數(shù)組對象

var str = 'abc';

Array.prototype.forEach.call(str, function(item, index, array) {

console.log( item + ':' + index);

});

//a:0

//b:1

//c:2

與for循環(huán)不同,對于稀疏數(shù)組,forEach()方法不會在實際上不存在元素的序號上調(diào)用函數(shù)

var a = [1,2,3];

delete a[1];

for(var i = 0; i < a.length; i++){

console.log(a[i]);

}

//1

//undefined

//3 

a.forEach(function(item,index,arr){console.log(item)});

//1

//3

forEach()方法無法在所有元素都傳遞給調(diào)用的函數(shù)之前終止遍歷。也就是說,沒有像for循環(huán)中使用的相應(yīng)的break語句。如果要提前終止,必須把forEach()方法放在一個try塊中,并能拋出一個異常

for(var i = 0; i < 5; i++){

if(i == 2) break;

}

console.log(i);//2 

var a = [1,2,3,4,5];

console.log(a.forEach(function(item,index,arr){

if(index == 2) break;//Uncaught SyntaxError: Illegal break statement

})); 

var a = [1,2,3,4,5];

a.forEach(function(item,index,arr){

try{

if(item == 2) throw new Error; 

}catch(e){

console.log(item);

}

});

forEach()方法兼容寫法

if(typeof Array.prototype.forEach != 'function'){

Array.prototype.forEach = function(fn,context){

for(var k = 0,length = this.length; k < length; k++){

if(typeof fn === 'function' && Object.prototype.hasOwnProperty.call(this,k)){

fn.call(context,this[k],k,this);

}

}

}

}

【filter()】

filter()方法對數(shù)組中的每一項運行給定函數(shù),返回該函數(shù)會返回true的項組成的數(shù)組。該方法常用于查詢符合條件的所有數(shù)組項

[1, 2, 3, 4, 5].filter(function (elem) {

return (elem > 3);

});// [4, 5]

[0, 1, 'a', false].filter(Boolean);// [1, "a"]

[1, 2, 3, 4, 5].filter(function (elem, index, arr) {

return index % 2 === 0;

});// [1, 3, 5]

filter()方法還可以接受第二個參數(shù),指定測試函數(shù)所在的上下文對象(this對象)

var Obj = function () {

this.MAX = 3;

};

var myFilter = function (item) {

if (item > this.MAX) {

return true;

}

};

var arr = [2, 8, 3, 4, 1, 3, 2, 9];

arr.filter(myFilter, new Obj());// [8, 4, 9]

filter()會跳過稀疏數(shù)組中缺少的元素,它的返回數(shù)組總是稠密的,所以可以壓縮稀疏數(shù)組的空缺

var a = [1,2,,,,3,,,,4];

console.log(a.length);//10

var dense = a.filter(function(){return true;})

console.log(dense,dense.length);//[1,2,3,4] 4

如果要壓縮空缺并刪除undefined和null元素,可以這樣使用filter()方法

var a = [1,2,,undefined,,3,,null,,4];

console.log(a.length);//10

var dense = a.filter(function(item){return item!= undefined;})

console.log(dense,dense.length);//[1,2,3,4] 4

filter()方法兼容寫法

if (typeof Array.prototype.filter != "function") {

Array.prototype.filter = function (fn, context) {

var arr = [];

if (typeof fn === "function") {

for (var k = 0, length = this.length; k < length; k++) {

fn.call(context, this[k], k, this) && arr.push(this[k]);

}

}

return arr;

};

}

【some()】

some()方法對數(shù)組中的每一項運行給定函數(shù),如果該函數(shù)對任一項返回true,則返回true。并且當(dāng)且僅當(dāng)數(shù)值中的所有元素調(diào)用判定函數(shù)都返回false,它才返回false

a = [1,2,3,4,5];

a.some(function(elem, index, arr){return elem%2===0;})//true

a.some(isNaN);//false

在空數(shù)組上調(diào)用some()方法會返回false

[].some(function(){});//false

some()方法兼容寫法

if (typeof Array.prototype.some != "function") {

Array.prototype.some = function (fn, context) {

var passed = false;

if (typeof fn === "function") {

for (var k = 0, length = this.length; k < length; k++) {

if (passed === true) break;

passed = !!fn.call(context, this[k], k, this);

}

}

return passed;

};

}

【every()】

every()方法對數(shù)組中的每一項運行給定函數(shù),如果該函數(shù)對每一項都返回true,則返回true;只要有一項返回false,則返回false

a = [1,2,3,4,5];

a.every(function(elem, index, arr){elem < 10;})//true

a.every(function(elem, index, arr){return elem%2 ===0;});//false

在空數(shù)組上調(diào)用every()方法會返回true

[].every(function(){});//true

every()方法兼容寫法

if (typeof Array.prototype.every != "function") {

Array.prototype.every = function (fn, context) {

var passed = true;

if (typeof fn === "function") {

for (var k = 0, length = this.length; k < length; k++) {

if (passed === false) break;

passed = !!fn.call(context, this[k], k, this);

}

}

return passed;

};

}

總結(jié)

javascript數(shù)組方法特意定義為通用的,因此它們不僅應(yīng)用在真正的數(shù)組而且在類數(shù)組對象上都能正確工作。這22種方法中,除了toString()和toLocaleString()以外的所有方法都是通用的

可以改變原數(shù)組的方法總共有7種:包括unshift()、shift()、push()、pop()這4種棧和隊列方法,reverse()和sort()這2種數(shù)組排列方法,數(shù)組刪改方法splice()

以上所述是小編給大家介紹的JavaScript中數(shù)組的22種方法必學(xué)(推薦),希望對大家有所幫助

更多信息請查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機網(wǎng)站地址:JavaScript中數(shù)組的22種方法必學(xué)(推薦)
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65317125(9:00—18:00) 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)