成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

jQuery數組處理完全詳解(實例演示)

開發 前端
jQuery的數組處理、便捷、功能齊全。最近的項目中用到的比較多,深感實用,一步到位的封裝了很多原生JavaScript數組不能企及的功能。

jQuery的數組處理、便捷、功能齊全。最近的項目中用到的比較多,深感實用,一步到位的封裝了很多原生JavaScript數組不能企及的功能。最近時間緊迫,今天抽了些時間回過頭來看jQuery中文文檔中對數組的介紹,順便對jQuery數組做個總結,溫故而知新。

強烈建議你打開DEMO演示后再看下面的詳解:http://mrthink.net/demo/ijq20101125.htm

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

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

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

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

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

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

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

  1. $.grep(_mozi,function(val,key){  
  2.     //過濾函數有兩個參數,***個為當前元素,第二個為元素索引  
  3.     if(val=='墨子'){  
  4.         alert('數組值為 墨子 的下標是: '+key);  
  5.     }  
  6. });  
  7.    
  8. var _moziGt1=$.grep(_mozi,function(val,key){  
  9.     return key>1;  
  10. });  
  11. alert('_mozi數組中索引值大于1的元素為: '+_moziGt1);  
  12.    
  13. var _moziLt1=$.grep(_mozi,function(val,key){  
  14.     return key>1;  
  15. },true);  
  16. //此處傳入了第三個可靠參數,對過濾函數中的返回值取反  
  17. alert('_mozi數組中索引值小于等于1的元素為: '+_moziLt1); 

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

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

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

  1. var _mapArrA=$.map(_mozi,function(val){  
  2.     return val+'[新加]';  
  3. });  
  4. var _mapArrB=$.map(_mozi,function(val){  
  5.     return val=='墨子' ? '[只給墨子加]'+val : val;  
  6. });  
  7. var _mapArrC=$.map(_mozi,function(val){  
  8.     //為數組元素擴展一個新元素  
  9.     return [val,(val+'[擴展]')];  
  10. });  
  11. alert('在每個元素后面加\'[新加]\'字符后的數組為: '+ _mapArrA);  
  12. alert('只給元素 墨子 添加字符后的數組為: '+ _mapArrB);  
  13. alert('為原數組中每個元素,擴展一個添加字符\'[新加]\'的元素,返回的數組為 '+_mapArrC); 

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

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

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

  1. var _exist=$.inArray('墨子',_mozi);  
  2. var _inexistence=$.inArray('衛鞅',_mozi)  
  3. if(_exist>=0){  
  4.     alert('墨子 存在于數組_mozi中,其在數組中索引值是: '+_exist);  
  5. }  
  6. if(_inexistence<0){  
  7.     alert('衛鞅 不存在于數組_mozi中!,返回值為: '+_inexistence+'!');  

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

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

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

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

解釋: 刪除數組中重復元素. 只處理刪除DOM元素數組,而不能處理字符串或者數字數組。

***次看到這個方法,覺得這是個很便捷的方法, 可以過濾重復,多***。但仔細一看, 僅限處理DOM元素,功能8折了。所以, 我給它定義成了一個不常用的元素, 至少, 我用jQuery以來沒用到過它。

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

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

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

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

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

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

解釋: 把jQuery集合中所有DOM元素恢復成一個數組。并不常用的方法, 個人甚至覺得它和$.makeArray一樣多余.

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

原文鏈接:http://mrthink.net/jquery-array-eachgrepinarray/

【編輯推薦】

  1. 兼容第三方框架 jQuery多庫共存機制詳解
  2. jQuery 1.4實用技巧大放送
  3. JQuery創建DOM元素方法解析
  4. jQuery的運行機制和設計理念 
責任編輯:王曉東 來源: mrthink.net
相關推薦

2009-11-05 16:27:31

接入網設備

2024-12-17 18:17:13

Python開發

2010-06-24 09:45:15

Linux RPMYUM

2009-10-14 15:58:59

布線系統管理

2022-11-16 08:41:43

2024-04-07 07:49:05

C#Switch模式匹配

2009-09-10 18:55:07

2009-07-17 17:16:48

Spring iBAT

2009-09-02 11:18:10

C#動態數組

2010-03-02 13:43:01

WCF事務演示

2010-05-27 09:38:59

MySQL Grant

2009-08-18 10:17:25

C#枚舉類型

2010-04-20 08:53:42

Oracle左連接

2010-04-21 15:02:50

Oracle使用游標

2010-05-18 09:02:55

MySQL條件查詢

2010-04-14 12:51:04

Oracle動態

2024-05-15 15:27:39

2024-01-03 16:01:23

2010-07-21 09:50:12

SQL Server子

2010-07-05 15:04:36

SQL Server刪
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品永久免费 | 精品久久久久久久久久久久 | 日韩电影中文字幕 | 成人国产免费观看 | 欧美成人a∨高清免费观看 老司机午夜性大片 | 精品国产一二三区 | 精品人伦一区二区三区蜜桃网站 | 99资源| 91高清视频在线观看 | 夜夜操天天干 | 国产高清精品一区二区三区 | av超碰| 日韩av中文 | 精品国产乱码久久久久久1区2区 | 欧美三区在线观看 | 三级成人在线 | 97国产一区二区 | www国产亚洲精品久久网站 | 久久国内精品 | 久久99精品久久 | 精品国产一区二区三区性色av | 日韩色在线 | 羞羞视频网站免费观看 | 99成人| 亚洲精久久久 | 国产精品久久久久久久免费大片 | 日韩在线观看一区二区三区 | 伦理片97| 看毛片网站 | 一区二区在线观看av | 欧美在线视频网 | 男女污污网站 | 精品成人一区二区 | 伊人热久久 | 日日干天天操 | 日韩羞羞| 亚洲www啪成人一区二区 | 欧美电影一区 | 精品久久久久久国产 | 九一视频在线播放 | 日韩伦理电影免费在线观看 |