jQuery之數組處理函數


摘要:$.each,$.grep,$.map,$.merge,$.inArray,$.unique,$.makeArray


 

1. $.each(array, [callback]) 遍歷[常用]

解釋: 不同於例遍jQuery對象的$().each()方法,此方法可用於例遍任何對象。回調函數擁有兩個參數:第一個為對象的成員或數組的索引, 第二個為對應變量或內容. 如果需要退出each循環可使回調函數返回false, 其它返回值將被忽略。

each遍歷,相信都不陌生,在平常的事件處理中,是for循環的變體,但比for循環強大。在數組中,它可以輕松的攻取數組索引及對應的值。例:

 var _language=['java','python','c','c++','c#']; //本文所用到的數組, 下同
$.each(_language,function(key,val){
//回調函數有兩個參數,第一個是元素索引,第二個為當前值
console.log('_language數組中 ,索引 : '+key+' 對應的值為: '+val);
});

相對於原生的for..in,each更強壯一點。for..in也可以遍歷數組,並返回對應索引,但值是需要通過arrName[key]來獲取。

2. $.grep(array, callback, [invert])過濾數組[常用]

解釋: 使用過濾函數過濾數組元素.

array:待過濾數組;
callback:處理數組中的每個元素,並過濾元素,該函數中包含兩個參數,第一個是當前數組元素的值,一個是當前數組元素的下標,即元素索引值。此函數應返回一個布爾值。另外,此函數可設置為一個字符串,當設置為字符串時,將視為“lambda-form”(縮寫形式?),其中 a 代表數組元素,i 代表元素索引值。如“a > 0”代表“function(a){ return a > 0; }”
invert:布爾型可選項,默認值false,值為true或false, 如果 “invert” 為 false 或為設置,則函數返回數組中由過濾函數返回 true 的元素,當”invert” 為 true,則返回過濾函數中返回 false 的元素集。

此函數至少傳遞兩個參數(第三個參數為true或false,對過濾函數返回值取反,個人覺得用處不大): 待過濾數組和過濾函數. 過濾函數必須返回true以保留元素或 false 以刪除元素. 另外,過濾函數還可以是可設置為一個字條串。

$.grep(_language,function(val,key){
//過濾函數有兩個參數,第一個為當前元素,第二個為元素索引
if(val=='java'){
    console.log('數組值為 java 的下標是: '+key);
}
});
var _languageGt1=$.grep(_languagei,function(val,key){
return key>1;
});
console.log('_languagei數組中索引值大於1的元素為: '+_languageGt1);
var _languageLt1=$.grep(_language,function(val,key){
return key>1;
},true);
//此處傳入了第三個可靠參數,對過濾函數中的返回值取反
console.log('_language數組中索引值小於等於1的元素為: '+_languageLt1);

3. $.map(array,[callback])按給定條件轉換數組 [一般]

解釋:作為參數的轉換函數會為每個數組元素調用, 而且會給這個轉換函數傳遞一個表示被轉換的元素作為參數. 轉換函數可以返回轉換后的值、null(刪除數組中的項目)或一個包含值的數組, 並擴展至原始數組中。

這個是個很強大的方法,但並不常用. 它可以根據特定條件,更新數組元素值,或根據原值擴展一個新的副本元素。

var _mapArrA=$.map(_language,function(val){
return val+'[新加]';
});
var _mapArrB=$.map(_language,function(val){
return val=='java' ? '[只給java加]'+val : val;
});
var _mapArrC=$.map(_language,function(val){
//為數組元素擴展一個新元素

return [val,(val+'[擴展]')];

});

console.log('在每個元素后面加'[新加]'字符后的數組為: '+ _mapArrA);
console.log('只給元素 java 添加字符后的數組為: '+ _mapArrB);
console.log('為原數組中每個元素,擴展一個添加字符'[新加]'的元素,返回的數組為 '+_mapArrC);

4 .$.inArray(val,array)判斷值是否存在於數組中[常用]

解釋: 確定第一個參數在數組中的位置, 從0開始計數(如果沒有找到則返回-1)。

記得indexOf()方法了嗎? indexOf()返回字符串的首次出現位置,而$.inArray()返回的是傳入參數在數組中的位置,同樣的,如果找到的,返回的是一個大於或等於0的值,若未找到則返回-1.現在, 知道怎么用了吧. 有了它, 判斷某個值是否存在於數組中,就變得輕而易舉了。

var _exist=$.inArray('java',_language);
var _inexistence=$.inArray('javascript',_language)
if(_exist>=0){
console.log('java 存在於數組_language中,其在數組中索引值是: '+_exist);
}
if(_inexistence<0){
alert('javascript 不存在於數組_language中!,返回值為: '+_inexistence+'!');
}

5 .$.merge(first,second)合並兩個數組[一般]

解釋: 返回的結果會修改第一個數組的內容——第一個數組的元素后面跟着第二個數組的元素。這個方法是用jQuery的方法替代原生concat()方法, 但功能並沒有concat()強大, concat()可以同時合並多個數組。

//原生concat()可能比它還簡潔點
_languageNew=$.merge(_language,['ios','androad','html','css'])
console.log('合並后新數組長度為: '+_languageNew.length+'. 其值為: '+_languageNew);

6 .$.unique(array)過濾數組中重復元素[不常用]

解釋: 刪除數組中重復元素. 只處理刪除DOM元素數組,而不能處理字符串或者數字數組。 可以過濾重復,但僅限處理DOM元素。所以, 我給它定義成了一個不常用的元素。

var _h2Arr=$.makeArray(h2obj);
//將數組_h2Arr重復一次
_h2Arr=$.merge(_h2Arr,_h2Arr);
var _curLen=_h2Arr.length;
_h2Arr=$.unique(_h2Arr);
var _newLen=_h2Arr.length;
alert('數組_h2Arr原長度值為: '+_curLen+' ,過濾后為: '+_newLen +' .共過濾 '+(_curLen-_newLen)+'個重復元素')

7. $.makeArray(obj) 將類數組對象轉換為數組[不常用]

解釋: 將類數組對象轉換為數組對象, 類數組對象有 length 屬性,其成員索引為0至 length-1。

這是個多余的方法, 無所不能的$本來就包含了這個功能。jQuery官網上解釋的非常模糊,其實, 它就是將某個類數組對象(比如用getElementsByTagName獲取的元素對象集合)轉換成數組對象。

var _makeArr=$.makeArray(h2obj);
console.log('h2元素對象集合的數據類型轉換為: '+_makeArr.constructor.name);//輸出Array

8. $(dom).toArray()將所有DOM元素恢復成數組[不常用]

解釋: 把jQuery集合中所有DOM元素恢復成一個數組。並不常用的方法.

ar _toArr=$('h2').toArray();
console.log('h2元素集合恢復后的數據類型是: '+_toArr.constructor.name);

 


參考資料

http://www.111cn.net/wy/jquery/46753.htm


 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM