首頁  >  文章  >  web前端  >  jquery基之數組的使用

jquery基之數組的使用

怪我咯
怪我咯原創
2017-06-29 10:54:431071瀏覽

jQuery的陣列處理、便利、功能齊全。一步到位的封裝了許多原生JavaScript陣列不能企及的功能。下面是jquery數組的使用詳解,需要的朋友可以參考下

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

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

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

程式碼如下:

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 以刪除元素. 另外,過濾函數還可以是可設定為一個字條串。

程式碼如下:

$.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);

3. $.map(array,[callback])以給定條件轉換陣列[一般]

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

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

 程式碼如下:

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(&#39;卫鞅 不存在于数组_mozi中!,返回值为: &#39;+_inexistence+&#39;!&#39;);  
}

5 .$.merge(first,second)合併兩個陣列[一般]

##解釋: 傳回的結果會修改第一個陣列的內容-第一個陣列的元素後面跟著第二個陣列的元素。這個方法是用jQuery的方法取代原生concat()方法, 但功能並沒有concat()強大, concat()可以同時合併多個陣列。

程式碼如下:

//原生concat()可能比它还简洁点  
_moziNew=$.merge(_mozi,[&#39;鬼谷子&#39;,&#39;商鞅&#39;,&#39;孙膑&#39;,&#39;庞涓&#39;,&#39;苏秦&#39;,&#39;张仪&#39;])  
alert(&#39;合并后新数组长度为: &#39;+_moziNew.length+&#39;. 其值为: &#39;+_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(&#39;数组_h2Arr原长度值为: &#39;+_curLen+&#39; ,过滤后为: &#39;+_newLen  
      +&#39; .共过滤 &#39;+(_curLen-_newLen)+&#39;个重复元素&#39;)

7. $.makeArray(obj) 將類別陣列物件轉換為陣列[不常用]


解釋: 將類別陣列物件轉換為陣列物件, 類別陣列物件有length 屬性,其成員索引為0至length-1。
這是個多餘的方法, 無所不能的$本來就包含了這個功能。 jQuery官網上解釋的非常模糊,其實, 它就是將某個類別數組物件(比如用
getElementsByTagName取得的元素物件集合)轉換成陣列物件。
 程式碼如下:

var _makeArr=$.makeArray(h2obj);  
alert(&#39;h2元素对象集合的数据
类型转换
为: &#39;+_makeArr.constructor.name);//输出Array

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


#解釋: 把jQuery集合中所有DOM元素還原成一個陣列。不常用的方法, 個人甚至覺得它和$.makeArray一樣多餘.

 程式碼如下:

var _toArr=$(&#39;h2&#39;).toArray();  
alert(&#39;h2元素集合恢复后的
数据类型
是: &#39;+_toArr.constructor.name);

以上是jquery基之數組的使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn