jquery數(shù)組封裝使用方法分享(jquery數(shù)組遍歷)
$.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 arr = ['javascript', 'php', 'java', 'c++', 'c#', 'perl', 'vb', 'html', 'css', 'objective-c'];
$.each(arr, function(key, val) {
// firebug console
console.log('index in arr:' + key + ", corresponding value:" + val);
// 如果想退出循環(huán)
// return false;
});
再來(lái)個(gè)測(cè)試程序:
[/code]
var fruit = ['蘋(píng)果','香蕉','橙子','哈密瓜','芒果'];
//用原生getElementsByTagName獲取h2元素的對(duì)象集合
var h2obj=document.getElementsByTagName('h2');
//$.each()遍歷數(shù)組
$('input#js_each').click(function(){
$.each(fruit,function(key,val){
//回調(diào)函數(shù)有兩個(gè)參數(shù),第一個(gè)是元素索引,第二個(gè)為當(dāng)前值
alert('fruit數(shù)組中,索引:'+key+'對(duì)應(yīng)的值為:'+val);
});
});
[/code]
相對(duì)于原生的for..in,each更強(qiáng)壯一點(diǎn). for..in也可以遍歷數(shù)組,并返回對(duì)應(yīng)索引,但值是需要通過(guò)arrName[key]來(lái)獲取;
$.grep(array, callback, [invert])過(guò)濾
使用過(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è)人不推薦,欲了解自行查閱);
v[code]ar temp = [];
temp = $.grep(arr, function(val, key) {
if(val.indexOf('c') != -1)
return true;
// 如果[invert]參數(shù)不給或?yàn)閒alse, $.grep只收集回調(diào)函數(shù)返回true的數(shù)組元素
// 反之[invert]參數(shù)為true, $.grep收集回調(diào)函數(shù)返回false的數(shù)組元素
}, false);
console.dir(temp);
再來(lái)個(gè)測(cè)試程序:
//$.grep()過(guò)濾數(shù)組
$('input#js_grep').click(function(){
$.grep(fruit,function(val,key){
//過(guò)濾函數(shù)有兩個(gè)參數(shù),第一個(gè)為當(dāng)前元素,第二個(gè)為元素索引
if(val=='芒果'){
alert('數(shù)組值為 芒果 的下標(biāo)是: '+key);
}
});
var _moziGt1=$.grep(fruit,function(val,key){
return key>1;
});
alert('fruit數(shù)組中索引值大于1的元素為: '+_moziGt1);
var _moziLt1=$.grep(fruit,function(val,key){
return key>1;
},true);
//此處傳入了第三個(gè)可靠參數(shù),對(duì)過(guò)濾函數(shù)中的返回值取反
alert('fruit數(shù)組中索引值小于等于1的元素為: '+_moziLt1);
});
$.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è)新的副本元素.
//1.6之前的版本只支持?jǐn)?shù)組
temp = $.map(arr, function(val, key) {
//返回null,返回的數(shù)組長(zhǎng)度減1
if(val === 'vb') return null;
return val;
});
console.dir(temp);
//1.6開(kāi)始支持json格式的object
var obj = {key1: 'val1', key2: 'val2', key3: 'val3'};
temp = $.map(obj, function(val, key) {
return val;
});
console.dir(temp);
再來(lái)個(gè)測(cè)試程序:
//$.map()按給定條件轉(zhuǎn)換數(shù)組
$('input#js_map').click(function(){
var _mapArrA=$.map(fruit,function(val){
return val+'[新加]';
});
var _mapArrB=$.map(fruit,function(val){
return val=='蘋(píng)果' ? '[只給蘋(píng)果加]'+val : val;
});
var _mapArrC=$.map(fruit,function(val){
//為數(shù)組元素?cái)U(kuò)展一個(gè)新元素
return [val,(val+'[擴(kuò)展]')];
});
alert('在每個(gè)元素后面加\'[新加]\'字符后的數(shù)組為: '+ _mapArrA);
alert('只給元素 蘋(píng)果 添加字符后的數(shù)組為: '+ _mapArrB);
alert('為原數(shù)組中每個(gè)元素,擴(kuò)展一個(gè)添加字符\'[新加]\'的元素,返回的數(shù)組為 '+_mapArrC);
});
$.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ù)組中,就變得輕而易舉了.
//返回元素在數(shù)組中的位置,0為起始位置,返回-1則未找到該元素
console.log($.inArray('javascript', arr));
測(cè)試程序:
[code]
//$.inArray判斷值是否在數(shù)組中,不存在返回-1,存在則返回對(duì)應(yīng)索引值
$('input#js_inarray').click(function(){
var _exist=$.inArray('芒果',fruit);
var _inexistence=$.inArray('榴蓮',fruit)
if(_exist>=0){
alert('芒果 存在于數(shù)組fruit中,其在數(shù)組中索引值是: '+_exist);
}
if(_inexistence< 0){
alert('榴蓮 不存在于數(shù)組fruit中!,返回值為: '+_inexistence+'!');
}
});
$.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ù)組.
var frontEnd = ['javascript', 'css', 'html'],
backEnd = ['java', 'php', 'c++'];
// 這種方式會(huì)修改第一個(gè)參數(shù), 即frontEnd數(shù)組
temp = $.merge(frontEnd, backEnd);
console.dir(temp);
console.dir(frontEnd);
// 可以用下面的方式來(lái)避免對(duì)原數(shù)組的影響
// $.merge($.merge([], frontEnd), backEnd);
測(cè)試程序
//$.merge()合并兩個(gè)數(shù)組
$('input#js_merge').click(function(){
//原生concat()可能比它還簡(jiǎn)潔點(diǎn)
fruitNew=$.merge(fruit,['水蜜桃','火龍果','西瓜','楊桃','荔枝','龍眼'])
alert('合并后新數(shù)組長(zhǎng)度為: '+fruitNew.length+'. 其值為: '+fruitNew);
});
$.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ò)它.
<div>blahblahblah....</div>
<div></div>
<div class="dup"></div>
<div class="dup"></div>
<div class="dup"></div>
<div></div>
// $.unique只支持DOM元素?cái)?shù)組,去除重復(fù)DOM元素,不支持其他類型數(shù)組(String或者Number)
// 獲得原始的DOM數(shù)組,而不是jQuery封裝的
var divs = $('div').get();
// 增加幾個(gè)class為dup的div
divs = divs.concat($('div.dup').get());
console.log("before unique:" + divs.length);
divs = $.unique(divs);
console.log("after unique:" + divs.length);
測(cè)試程序:
//$.unique()過(guò)濾數(shù)組中重復(fù)元素(僅限D(zhuǎn)OM元素?cái)?shù)組)
$('input#js_unique').click(function(){
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ù)元素');
});
$.makeArray(obj) 將類數(shù)組對(duì)象轉(zhuǎn)換為數(shù)組
將類數(shù)組對(duì)象轉(zhuǎn)換為數(shù)組對(duì)象, 類數(shù)組對(duì)象有 length 屬性,其成員索引為0至 length-1.這是個(gè)多余的方法, 無(wú)所不能的$本來(lái)就包含了這個(gè)功能. jQuery官網(wǎng)上解釋的非常模糊. 其實(shí), 它就是將某個(gè)類數(shù)組對(duì)象(比如用getElementsByTagName獲取的元素對(duì)象集合)轉(zhuǎn)換成數(shù)組對(duì)象.
首先什么是類數(shù)組對(duì)象?jQuery官網(wǎng)上用divs = getElementsByTag('div')來(lái)做例子,這個(gè)divs有類似數(shù)組的一些方法比如length,通過(guò)[index]方式獲取元素等,然后通過(guò)$.makeArray(divs)使它轉(zhuǎn)為數(shù)組,就可以用數(shù)組的其他功能,比如reverse(), pop()等。
//$.makeArr()類數(shù)組轉(zhuǎn)換
$('input#js_makearray').click(function(){
var _makeArr=$.makeArray(h2obj);
alert('h2元素對(duì)象集合的數(shù)據(jù)類型轉(zhuǎn)換為: '+_makeArr.constructor.name);
});
$(dom).toArray()將所有DOM元素恢復(fù)成數(shù)組
把jQuery集合中所有DOM元素恢復(fù)成一個(gè)數(shù)組;并不常用的方法, 個(gè)人甚至覺(jué)得它和$.makeArray一樣多余.
//$(dom).toArray()將所有DOM元素恢復(fù)成數(shù)組
$('input#js_toarray').click(function(){
var _toArr=$('h2').toArray();
alert('h2元素集合恢復(fù)后的數(shù)據(jù)類型是: '+_toArr.constructor.name);
相關(guān)文章
jQuery實(shí)現(xiàn)圣誕節(jié)禮物動(dòng)畫(huà)案例解析
這篇文章主要介紹了jQuery實(shí)現(xiàn)圣誕節(jié)禮物動(dòng)畫(huà)案例解析的相關(guān)資料,需要的朋友可以參考下2016-12-12jQuery 瀑布流 浮動(dòng)布局(一)(延遲AJAX加載圖片)
瀑布流:這種布局適合于小數(shù)據(jù)塊,每個(gè)數(shù)據(jù)塊內(nèi)容相近且沒(méi)有側(cè)重。通常,隨著頁(yè)面滾動(dòng)條向下滾動(dòng),這種布局還會(huì)不斷加載數(shù)據(jù)塊并附加至當(dāng)前尾部2012-05-05JQuery調(diào)用綁定click事件的3種寫(xiě)法
這篇文章主要介紹了JQuery調(diào)用綁定click事件的3種寫(xiě)法,本文簡(jiǎn)潔清晰的給出3種寫(xiě)法的代碼示例,可以很方便的復(fù)制使用,需要的朋友可以參考下2015-03-03jquery實(shí)現(xiàn)全屏滾動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了jquery實(shí)現(xiàn)全屏滾動(dòng)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08jquery easyui combobox模糊過(guò)濾(示例代碼)
這篇文章主要介紹了jquery easyui combobox模糊過(guò)濾(示例代碼)。需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2013-11-11Jquery chosen動(dòng)態(tài)設(shè)置值實(shí)例介紹
Jquery chosen一款選擇插件,支持檢索,多選,但不支持輸入效果,下面與大家分享下其使用示例,感興趣的朋友可以參考下,希望對(duì)大家有所幫助2013-08-08jQuery 選擇器項(xiàng)目實(shí)例分析及實(shí)現(xiàn)代碼
首先廢話一句,jQuery選擇器真心很強(qiáng)大!接下來(lái)詳細(xì)介紹jQuery 選擇器項(xiàng)目實(shí)例實(shí)現(xiàn)方式2012-12-12jquery通過(guò)擴(kuò)展select控件實(shí)現(xiàn)支持enter或focus選擇的方法
這篇文章主要介紹了jquery通過(guò)擴(kuò)展select控件實(shí)現(xiàn)支持enter或focus選擇的方法,通過(guò)jQuery針對(duì)select空間增加enter及focus選擇功能分析了jQuery擴(kuò)展的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2015-11-11