Jquery 數(shù)組操作大全個(gè)人總結(jié)
更新時(shí)間:2013年11月13日 15:41:09 作者:
jQuery的數(shù)組處理,便捷,功能齊全. 最近的項(xiàng)目中用到的比較多,最近時(shí)間緊迫,今天抽了些時(shí)間回過(guò)頭來(lái)看 jQuery中文文檔順便對(duì)jQuery數(shù)組做個(gè)總結(jié)
jQuery的數(shù)組處理,便捷,功能齊全. 最近的項(xiàng)目中用到的比較多,深感實(shí)用,一步到位的封裝了很多原生js數(shù)組不能企及的功能. 最近時(shí)間緊迫,今天抽了些時(shí)間回過(guò)頭來(lái)看 jQuery中文文檔 中對(duì)數(shù)組的介紹,順便對(duì)jQuery數(shù)組做個(gè)總結(jié).溫故,知新.
強(qiáng)烈建議你打開(kāi)DEMO演示后再看下面的詳解: 點(diǎn)此查看DEMO
1. $.each(array, [callback]) 遍歷[常用]
解釋: 不同于例遍 jQuery 對(duì)象的 $().each() 方法,此方法可用于例遍任何對(duì)象(不僅僅是數(shù)組哦~). 回調(diào)函數(shù)擁有兩個(gè)參數(shù):第一個(gè)為對(duì)象的成員或數(shù)組的索引, 第二個(gè)為對(duì)應(yīng)變量或內(nèi)容. 如果需要退出 each 循環(huán)可使回調(diào)函數(shù)返回 false, 其它返回值將被忽略.
each遍歷,相信都不陌生,在平常的事件處理中,是for循環(huán)的變體,但比f(wàn)or循環(huán)強(qiáng)大.在數(shù)組中,它可以輕松的攻取數(shù)組索引及對(duì)應(yīng)的值.例:
var _mozi=['墨家','墨子','墨翟','兼愛(ài)非攻','尚同尚賢']; //本文所用到的數(shù)組, 下同
$.each(_mozi,function(key,val){
//回調(diào)函數(shù)有兩個(gè)參數(shù),第一個(gè)是元素索引,第二個(gè)為當(dāng)前值
alert('_mozi數(shù)組中 ,索引 : '+key+' 對(duì)應(yīng)的值為: '+val);
});
相對(duì)于原生的for..in,each更強(qiáng)壯一點(diǎn). for..in也可以遍歷數(shù)組,并返回對(duì)應(yīng)索引,但值是需要通過(guò)arrName[key]來(lái)獲取;
2. $.grep(array, callback, [invert]) 過(guò)濾數(shù)組[常用]
解釋: 使用過(guò)濾函數(shù)過(guò)濾數(shù)組元素.此函數(shù)至少傳遞兩個(gè)參數(shù)(第三個(gè)參數(shù)為true或false,對(duì)過(guò)濾函數(shù)返回值取反,個(gè)人覺(jué)得用處不大): 待過(guò)濾數(shù)組和過(guò)濾函數(shù). 過(guò)濾函數(shù)必須返回 true 以保留元素或 false 以刪除元素. 另外,過(guò)濾函數(shù)還可以是可設(shè)置為一個(gè)字條串(個(gè)人不推薦,欲了解自行查閱);
$.grep(_mozi,function(val,key){
//過(guò)濾函數(shù)有兩個(gè)參數(shù),第一個(gè)為當(dāng)前元素,第二個(gè)為元素索引
if(val=='墨子'){
alert('數(shù)組值為 墨子 的下標(biāo)是: '+key);
}
});
var _moziGt1=$.grep(_mozi,function(val,key){
return key>1;
});
alert('_mozi數(shù)組中索引值大于1的元素為: '+_moziGt1);
var _moziLt1=$.grep(_mozi,function(val,key){
return key>1;
},true);
//此處傳入了第三個(gè)可靠參數(shù),對(duì)過(guò)濾函數(shù)中的返回值取反
alert('_mozi數(shù)組中索引值小于等于1的元素為: '+_moziLt1);
3. $.map(array,[callback])按給定條件轉(zhuǎn)換數(shù)組 [一般]
解釋:作為參數(shù)的轉(zhuǎn)換函數(shù)會(huì)為每個(gè)數(shù)組元素調(diào)用, 而且會(huì)給這個(gè)轉(zhuǎn)換函數(shù)傳遞一個(gè)表示被轉(zhuǎn)換的元素作為參數(shù). 轉(zhuǎn)換函數(shù)可以返回轉(zhuǎn)換后的值、null(刪除數(shù)組中的項(xiàng)目)或一個(gè)包含值的數(shù)組, 并擴(kuò)展至原始數(shù)組中.
這個(gè)是個(gè)很強(qiáng)大的方法,但并不常用. 它可以根據(jù)特定條件,更新數(shù)組元素值,或根據(jù)原值擴(kuò)展一個(gè)新的副本元素.
var _mapArrA=$.map(_mozi,function(val){
return val+'[新加]';
});
var _mapArrB=$.map(_mozi,function(val){
return val=='墨子' ? '[只給墨子加]'+val : val;
});
var _mapArrC=$.map(_mozi,function(val){
//為數(shù)組元素?cái)U(kuò)展一個(gè)新元素
return [val,(val+'[擴(kuò)展]')];
});
alert('在每個(gè)元素后面加\'[新加]\'字符后的數(shù)組為: '+ _mapArrA);
alert('只給元素 墨子 添加字符后的數(shù)組為: '+ _mapArrB);
alert('為原數(shù)組中每個(gè)元素,擴(kuò)展一個(gè)添加字符\'[新加]\'的元素,返回的數(shù)組為 '+_mapArrC);
4 .$.inArray(val,array)判斷值是否存在于數(shù)組中[常用]
解釋: 確定第一個(gè)參數(shù)在數(shù)組中的位置, 從0開(kāi)始計(jì)數(shù)(如果沒(méi)有找到則返回 -1 ).
記得indexOf()方法了嗎? indexOf()返回字符串的首次出現(xiàn)位置,而$.inArray()返回的是傳入?yún)?shù)在數(shù)組中的位置,同樣的,如果找到的,返回的是一個(gè)大于或等于0的值,若未找到則返回-1.現(xiàn)在, 知道怎么用了吧. 有了它, 判斷某個(gè)值是否存在于數(shù)組中,就變得輕而易舉了.
var _exist=$.inArray('墨子',_mozi);
var _inexistence=$.inArray('衛(wèi)鞅',_mozi)
if(_exist>=0){
alert('墨子 存在于數(shù)組_mozi中,其在數(shù)組中索引值是: '+_exist);
}
if(_inexistence<0){
alert('衛(wèi)鞅 不存在于數(shù)組_mozi中!,返回值為: '+_inexistence+'!');
}
5 .$.merge(first,second)合并兩個(gè)數(shù)組[一般]
解釋: 返回的結(jié)果會(huì)修改第一個(gè)數(shù)組的內(nèi)容——第一個(gè)數(shù)組的元素后面跟著第二個(gè)數(shù)組的元素.
這個(gè)方法是用jQuery的方法替代原生concat()方法, 但功能并沒(méi)有concat()強(qiáng)大, concat()可以同時(shí)合并多個(gè)數(shù)組.
//原生concat()可能比它還簡(jiǎn)潔點(diǎn)
_moziNew=$.merge(_mozi,['鬼谷子','商鞅','孫臏','龐涓','蘇秦','張儀'])
alert('合并后新數(shù)組長(zhǎng)度為: '+_moziNew.length+'. 其值為: '+_moziNew);
6 .$.unique(array)過(guò)濾數(shù)組中重復(fù)元素[不常用]
解釋: 刪除數(shù)組中重復(fù)元素. 只處理刪除DOM元素?cái)?shù)組,而不能處理字符串或者數(shù)字?jǐn)?shù)組.
第一次看到這個(gè)方法,覺(jué)得這是個(gè)很便捷的方法, 可以過(guò)濾重復(fù), 哈, 多完美, 但仔細(xì)一看, 僅限處理DOM元素. 功能8折了.所以, 我給它定義成了一個(gè)不常用的元素, 至少, 我用jQuery以來(lái)沒(méi)用到過(guò)它.
var _h2Arr=$.makeArray(h2obj);
//將數(shù)組_h2Arr重復(fù)一次
_h2Arr=$.merge(_h2Arr,_h2Arr);
var _curLen=_h2Arr.length;
_h2Arr=$.unique(_h2Arr);
var _newLen=_h2Arr.length;
alert('數(shù)組_h2Arr原長(zhǎng)度值為: '+_curLen+' ,過(guò)濾后為: '+_newLen
+' .共過(guò)濾 '+(_curLen-_newLen)+'個(gè)重復(fù)元素')
7. $.makeArray(obj) 將類(lèi)數(shù)組對(duì)象轉(zhuǎn)換為數(shù)組[不常用]
解釋: 將類(lèi)數(shù)組對(duì)象轉(zhuǎn)換為數(shù)組對(duì)象, 類(lèi)數(shù)組對(duì)象有 length 屬性,其成員索引為0至 length-1.
這是個(gè)多余的方法, 無(wú)所不能的$本來(lái)就包含了這個(gè)功能. jQuery官網(wǎng)上解釋的非常模糊. 其實(shí), 它就是將某個(gè)類(lèi)數(shù)組對(duì)象(比如用getElementsByTagName獲取的元素對(duì)象集合)轉(zhuǎn)換成數(shù)組對(duì)象.
var _makeArr=$.makeArray(h2obj);
alert('h2元素對(duì)象集合的數(shù)據(jù)類(lèi)型轉(zhuǎn)換為: '+_makeArr.constructor.name);//輸出Array
8. $(dom).toArray()將所有DOM元素恢復(fù)成數(shù)組[不常用]
解釋: 把jQuery集合中所有DOM元素恢復(fù)成一個(gè)數(shù)組;
并不常用的方法, 個(gè)人甚至覺(jué)得它和$.makeArray一樣多余.
var _toArr=$('h2').toArray();
alert('h2元素集合恢復(fù)后的數(shù)據(jù)類(lèi)型是: '+_toArr.constructor.name);
強(qiáng)烈建議你打開(kāi)DEMO演示后再看下面的詳解: 點(diǎn)此查看DEMO
1. $.each(array, [callback]) 遍歷[常用]
解釋: 不同于例遍 jQuery 對(duì)象的 $().each() 方法,此方法可用于例遍任何對(duì)象(不僅僅是數(shù)組哦~). 回調(diào)函數(shù)擁有兩個(gè)參數(shù):第一個(gè)為對(duì)象的成員或數(shù)組的索引, 第二個(gè)為對(duì)應(yīng)變量或內(nèi)容. 如果需要退出 each 循環(huán)可使回調(diào)函數(shù)返回 false, 其它返回值將被忽略.
each遍歷,相信都不陌生,在平常的事件處理中,是for循環(huán)的變體,但比f(wàn)or循環(huán)強(qiáng)大.在數(shù)組中,它可以輕松的攻取數(shù)組索引及對(duì)應(yīng)的值.例:
復(fù)制代碼 代碼如下:
var _mozi=['墨家','墨子','墨翟','兼愛(ài)非攻','尚同尚賢']; //本文所用到的數(shù)組, 下同
$.each(_mozi,function(key,val){
//回調(diào)函數(shù)有兩個(gè)參數(shù),第一個(gè)是元素索引,第二個(gè)為當(dāng)前值
alert('_mozi數(shù)組中 ,索引 : '+key+' 對(duì)應(yīng)的值為: '+val);
});
相對(duì)于原生的for..in,each更強(qiáng)壯一點(diǎn). for..in也可以遍歷數(shù)組,并返回對(duì)應(yīng)索引,但值是需要通過(guò)arrName[key]來(lái)獲取;
2. $.grep(array, callback, [invert]) 過(guò)濾數(shù)組[常用]
解釋: 使用過(guò)濾函數(shù)過(guò)濾數(shù)組元素.此函數(shù)至少傳遞兩個(gè)參數(shù)(第三個(gè)參數(shù)為true或false,對(duì)過(guò)濾函數(shù)返回值取反,個(gè)人覺(jué)得用處不大): 待過(guò)濾數(shù)組和過(guò)濾函數(shù). 過(guò)濾函數(shù)必須返回 true 以保留元素或 false 以刪除元素. 另外,過(guò)濾函數(shù)還可以是可設(shè)置為一個(gè)字條串(個(gè)人不推薦,欲了解自行查閱);
復(fù)制代碼 代碼如下:
$.grep(_mozi,function(val,key){
//過(guò)濾函數(shù)有兩個(gè)參數(shù),第一個(gè)為當(dāng)前元素,第二個(gè)為元素索引
if(val=='墨子'){
alert('數(shù)組值為 墨子 的下標(biāo)是: '+key);
}
});
var _moziGt1=$.grep(_mozi,function(val,key){
return key>1;
});
alert('_mozi數(shù)組中索引值大于1的元素為: '+_moziGt1);
var _moziLt1=$.grep(_mozi,function(val,key){
return key>1;
},true);
//此處傳入了第三個(gè)可靠參數(shù),對(duì)過(guò)濾函數(shù)中的返回值取反
alert('_mozi數(shù)組中索引值小于等于1的元素為: '+_moziLt1);
3. $.map(array,[callback])按給定條件轉(zhuǎn)換數(shù)組 [一般]
解釋:作為參數(shù)的轉(zhuǎn)換函數(shù)會(huì)為每個(gè)數(shù)組元素調(diào)用, 而且會(huì)給這個(gè)轉(zhuǎn)換函數(shù)傳遞一個(gè)表示被轉(zhuǎn)換的元素作為參數(shù). 轉(zhuǎn)換函數(shù)可以返回轉(zhuǎn)換后的值、null(刪除數(shù)組中的項(xiàng)目)或一個(gè)包含值的數(shù)組, 并擴(kuò)展至原始數(shù)組中.
這個(gè)是個(gè)很強(qiáng)大的方法,但并不常用. 它可以根據(jù)特定條件,更新數(shù)組元素值,或根據(jù)原值擴(kuò)展一個(gè)新的副本元素.
復(fù)制代碼 代碼如下:
var _mapArrA=$.map(_mozi,function(val){
return val+'[新加]';
});
var _mapArrB=$.map(_mozi,function(val){
return val=='墨子' ? '[只給墨子加]'+val : val;
});
var _mapArrC=$.map(_mozi,function(val){
//為數(shù)組元素?cái)U(kuò)展一個(gè)新元素
return [val,(val+'[擴(kuò)展]')];
});
alert('在每個(gè)元素后面加\'[新加]\'字符后的數(shù)組為: '+ _mapArrA);
alert('只給元素 墨子 添加字符后的數(shù)組為: '+ _mapArrB);
alert('為原數(shù)組中每個(gè)元素,擴(kuò)展一個(gè)添加字符\'[新加]\'的元素,返回的數(shù)組為 '+_mapArrC);
4 .$.inArray(val,array)判斷值是否存在于數(shù)組中[常用]
解釋: 確定第一個(gè)參數(shù)在數(shù)組中的位置, 從0開(kāi)始計(jì)數(shù)(如果沒(méi)有找到則返回 -1 ).
記得indexOf()方法了嗎? indexOf()返回字符串的首次出現(xiàn)位置,而$.inArray()返回的是傳入?yún)?shù)在數(shù)組中的位置,同樣的,如果找到的,返回的是一個(gè)大于或等于0的值,若未找到則返回-1.現(xiàn)在, 知道怎么用了吧. 有了它, 判斷某個(gè)值是否存在于數(shù)組中,就變得輕而易舉了.
復(fù)制代碼 代碼如下:
var _exist=$.inArray('墨子',_mozi);
var _inexistence=$.inArray('衛(wèi)鞅',_mozi)
if(_exist>=0){
alert('墨子 存在于數(shù)組_mozi中,其在數(shù)組中索引值是: '+_exist);
}
if(_inexistence<0){
alert('衛(wèi)鞅 不存在于數(shù)組_mozi中!,返回值為: '+_inexistence+'!');
}
5 .$.merge(first,second)合并兩個(gè)數(shù)組[一般]
解釋: 返回的結(jié)果會(huì)修改第一個(gè)數(shù)組的內(nèi)容——第一個(gè)數(shù)組的元素后面跟著第二個(gè)數(shù)組的元素.
這個(gè)方法是用jQuery的方法替代原生concat()方法, 但功能并沒(méi)有concat()強(qiáng)大, concat()可以同時(shí)合并多個(gè)數(shù)組.
復(fù)制代碼 代碼如下:
//原生concat()可能比它還簡(jiǎn)潔點(diǎn)
_moziNew=$.merge(_mozi,['鬼谷子','商鞅','孫臏','龐涓','蘇秦','張儀'])
alert('合并后新數(shù)組長(zhǎng)度為: '+_moziNew.length+'. 其值為: '+_moziNew);
6 .$.unique(array)過(guò)濾數(shù)組中重復(fù)元素[不常用]
解釋: 刪除數(shù)組中重復(fù)元素. 只處理刪除DOM元素?cái)?shù)組,而不能處理字符串或者數(shù)字?jǐn)?shù)組.
第一次看到這個(gè)方法,覺(jué)得這是個(gè)很便捷的方法, 可以過(guò)濾重復(fù), 哈, 多完美, 但仔細(xì)一看, 僅限處理DOM元素. 功能8折了.所以, 我給它定義成了一個(gè)不常用的元素, 至少, 我用jQuery以來(lái)沒(méi)用到過(guò)它.
復(fù)制代碼 代碼如下:
var _h2Arr=$.makeArray(h2obj);
//將數(shù)組_h2Arr重復(fù)一次
_h2Arr=$.merge(_h2Arr,_h2Arr);
var _curLen=_h2Arr.length;
_h2Arr=$.unique(_h2Arr);
var _newLen=_h2Arr.length;
alert('數(shù)組_h2Arr原長(zhǎng)度值為: '+_curLen+' ,過(guò)濾后為: '+_newLen
+' .共過(guò)濾 '+(_curLen-_newLen)+'個(gè)重復(fù)元素')
7. $.makeArray(obj) 將類(lèi)數(shù)組對(duì)象轉(zhuǎn)換為數(shù)組[不常用]
解釋: 將類(lèi)數(shù)組對(duì)象轉(zhuǎn)換為數(shù)組對(duì)象, 類(lèi)數(shù)組對(duì)象有 length 屬性,其成員索引為0至 length-1.
這是個(gè)多余的方法, 無(wú)所不能的$本來(lái)就包含了這個(gè)功能. jQuery官網(wǎng)上解釋的非常模糊. 其實(shí), 它就是將某個(gè)類(lèi)數(shù)組對(duì)象(比如用getElementsByTagName獲取的元素對(duì)象集合)轉(zhuǎn)換成數(shù)組對(duì)象.
復(fù)制代碼 代碼如下:
var _makeArr=$.makeArray(h2obj);
alert('h2元素對(duì)象集合的數(shù)據(jù)類(lèi)型轉(zhuǎn)換為: '+_makeArr.constructor.name);//輸出Array
8. $(dom).toArray()將所有DOM元素恢復(fù)成數(shù)組[不常用]
解釋: 把jQuery集合中所有DOM元素恢復(fù)成一個(gè)數(shù)組;
并不常用的方法, 個(gè)人甚至覺(jué)得它和$.makeArray一樣多余.
復(fù)制代碼 代碼如下:
var _toArr=$('h2').toArray();
alert('h2元素集合恢復(fù)后的數(shù)據(jù)類(lèi)型是: '+_toArr.constructor.name);
您可能感興趣的文章:
- jQuery實(shí)現(xiàn)tag便簽去重效果的方法
- jQuery表格排序組件-tablesorter使用示例
- jquery中的sortable排序之后的保存狀態(tài)的解決方法
- jquery tablesorter.js 支持中文表格排序改進(jìn)
- jQuery利用sort對(duì)DOM元素進(jìn)行排序操作
- 通過(guò)jquery-ui中的sortable來(lái)實(shí)現(xiàn)拖拽排序的簡(jiǎn)單實(shí)例
- jquery.tableSort.js表格排序插件使用方法詳解
- jquery中push()的用法(數(shù)組添加元素)
- jquery遍歷數(shù)組與篩選數(shù)組的方法
- jQuery簡(jiǎn)單實(shí)現(xiàn)對(duì)數(shù)組去重及排序操作實(shí)例
相關(guān)文章
JavaScript中的apply和call函數(shù)詳解
本文是翻譯Function.apply and Function.call in JavaScript,希望對(duì)大家有所幫助2014-07-07jQuery+html5+css3實(shí)現(xiàn)圓角無(wú)刷新表單帶輸入驗(yàn)證功能代碼
這篇文章主要介紹了jQuery+html5+css3實(shí)現(xiàn)圓角無(wú)刷新表單帶輸入驗(yàn)證功能代碼,加入了html5與css3技術(shù),使得整個(gè)表單效果更加唯美華麗,需要的朋友可以參考下2015-08-08jquery對(duì)象和javascript對(duì)象即DOM對(duì)象相互轉(zhuǎn)換
對(duì)于已經(jīng)是一個(gè) DOM 對(duì)象,只需要用 $() 把DOM對(duì)象包裝起來(lái),就可以獲得一個(gè) jQuery 對(duì)象了,使用[index]和.get(index)可以轉(zhuǎn)為DOM對(duì)象2014-08-08jquery實(shí)現(xiàn)隱藏與顯示動(dòng)畫(huà)效果/輸入框字符動(dòng)態(tài)遞減/導(dǎo)航按鈕切換
jquery實(shí)現(xiàn)隱藏顯示層動(dòng)畫(huà)效果、仿新浪字符動(dòng)態(tài)輸入、tab效果等等,以下為所有代碼,感興趣的朋友可以練練手哈,希望對(duì)大家學(xué)習(xí)有所幫助2013-07-07jquery?追加元素append、prepend、before、after用法與區(qū)別分析
在jquery中append、prepend、before、after方法是對(duì)數(shù)據(jù)元素節(jié)點(diǎn)的操作系列方法了,這些方法大家了解嗎?如果不了解就可以和小編來(lái)看看它們用法2016-12-12jQuery實(shí)現(xiàn)頁(yè)面倒計(jì)時(shí)并刷新效果
頁(yè)面倒計(jì)時(shí)小編在很多網(wǎng)站都有這樣的需求,今天小編給大家分享一段jq代碼實(shí)現(xiàn)頁(yè)面倒計(jì)時(shí)并刷新效果,代碼簡(jiǎn)單易懂,非常不錯(cuò),需要的的朋友參考下2017-03-03