Jquery 數組操做

轉自:http://www.jb51.net/article/43164.htm數組


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

解釋: 不一樣於例遍 jQuery 對象的 $().each() 方法,此方法可用於例遍任何對象(不單單是數組哦~). 回調函數擁有兩個參數:第一個爲對象的成員或數組的索引, 第二個爲對應變量或內容. 若是須要退出 each 循環可以使回調函數返回 false, 其它返回值將被忽略. 
each遍歷,相信都不陌生,在日常的事件處理中,是for循環的變體,但比for循環強大.在數組中,它能夠輕鬆的攻取數組索引及對應的值.例: 
dom

複製代碼代碼以下:ide


var _mozi=['墨家','墨子','墨翟','兼愛非攻','尚同尚賢']; //本文所用到的數組, 下同 
$.each(_mozi,function(key,val){ 
//回調函數有兩個參數,第一個是元素索引,第二個爲當前值 
alert('_mozi數組中 ,索引 : '+key+' 對應的值爲: '+val); 
}); 
函數


相對於原生的for..in,each更強壯一點. for..in也能夠遍歷數組,並返回對應索引,但值是須要經過arrName[key]來獲取; 

2. $.grep(array, callback, [invert]) 過濾數組[經常使用] 
解釋: 使用過濾函數過濾數組元素.此函數至少傳遞兩個參數(第三個參數爲true或false,對過濾函數返回值取反,我的以爲用處不大): 待過濾數組和過濾函數. 過濾函數必須返回 true 以保留元素或 false 以刪除元素. 另外,過濾函數還能夠是可設置爲一個字條串(我的不推薦,欲瞭解自行查閱); 
spa

複製代碼代碼以下:.net


$.grep(_mozi,function(val,key){ 
//過濾函數有兩個參數,第一個爲當前元素,第二個爲元素索引 
if(val=='墨子'){ 
alert('數組值爲 墨子 的下標是: '+key); 

}); 

var _moziGt1=$.grep(_mozi,function(val,key){ 
return key>1; 
}); 
alert('_mozi數組中索引值大於1的元素爲: '+_moziGt1); 

var _moziLt1=$.grep(_mozi,function(val,key){ 
return key>1; 
},true); 
//此處傳入了第三個可靠參數,對過濾函數中的返回值取反 
alert('_mozi數組中索引值小於等於1的元素爲: '+_moziLt1); 
orm


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

解釋:做爲參數的轉換函數會爲每一個數組元素調用, 並且會給這個轉換函數傳遞一個表示被轉換的元素做爲參數. 轉換函數能夠返回轉換後的值、null(刪除數組中的項目)或一個包含值的數組, 並擴展至原始數組中. 
這個是個很強大的方法,但並不經常使用. 它能夠根據特定條件,更新數組元素值,或根據原值擴展一個新的副本元素. 
htm

複製代碼代碼以下:對象


var _mapArrA=$.map(_mozi,function(val){ 
return val+'[新加]'; 
}); 
var _mapArrB=$.map(_mozi,function(val){ 
return val=='墨子' ? '[只給墨子加]'+val : val; 
}); 
var _mapArrC=$.map(_mozi,function(val){ 
//爲數組元素擴展一個新元素 
return [val,(val+'[擴展]')]; 
}); 
alert('在每一個元素後面加\'[新加]\'字符後的數組爲: '+ _mapArrA); 
alert('只給元素 墨子 添加字符後的數組爲: '+ _mapArrB); 
alert('爲原數組中每一個元素,擴展一個添加字符\'[新加]\'的元素,返回的數組爲 '+_mapArrC); 
索引


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

解釋: 肯定第一個參數在數組中的位置, 從0開始計數(若是沒有找到則返回 -1 ). 
記得indexOf()方法了嗎? indexOf()返回字符串的首次出現位置,而$.inArray()返回的是傳入參數在數組中的位置,一樣的,若是找到的,返回的是一個大於或等於0的值,若未找到則返回-1.如今, 知道怎麼用了吧. 有了它, 判斷某個值是否存在於數組中,就變得垂手可得了. 

複製代碼代碼以下:


var _exist=$.inArray('墨子',_mozi); 
var _inexistence=$.inArray('衛鞅',_mozi) 
if(_exist>=0){ 
alert('墨子 存在於數組_mozi中,其在數組中索引值是: '+_exist); 

if(_inexistence<0){ 
alert('衛鞅 不存在於數組_mozi中!,返回值爲: '+_inexistence+'!'); 


5 .$.merge(first,second)合併兩個數組[通常] 

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

複製代碼代碼以下:


//原生concat()可能比它還簡潔點 
_moziNew=$.merge(_mozi,['鬼谷子','商鞅','孫臏','龐涓','蘇秦','張儀']) 
alert('合併後新數組長度爲: '+_moziNew.length+'. 其值爲: '+_moziNew); 


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

解釋: 刪除數組中重複元素. 只處理刪除DOM元素數組,而不能處理字符串或者數字數組. 
第一次看到這個方法,以爲這是個很便捷的方法, 能夠過濾重複, 哈, 多完美, 但仔細一看, 僅限處理DOM元素. 功能8折了.因此, 我給它定義成了一個不經常使用的元素, 至少, 我用jQuery以來沒用到過它. 

複製代碼代碼以下:


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); 
alert('h2元素對象集合的數據類型轉換爲: '+_makeArr.constructor.name);//輸出Array 


8. $(dom).toArray()將全部DOM元素恢復成數組[不經常使用] 

解釋: 把jQuery集合中全部DOM元素恢復成一個數組; 
並不經常使用的方法, 我的甚至以爲它和$.makeArray同樣多餘. 

複製代碼代碼以下:

var _toArr=$('h2').toArray(); alert('h2元素集合恢復後的數據類型是: '+_toArr.constructor.name); 

相關文章
相關標籤/搜索