亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

Jquery 數組操作大全個人總結

2019-11-20 21:42:57
字體:
來源:轉載
供稿:網友
jQuery的數組處理,便捷,功能齊全. 最近的項目中用到的比較多,深感實用,一步到位的封裝了很多原生js數組不能企及的功能. 最近時間緊迫,今天抽了些時間回過頭來看 jQuery中文文檔 中對數組的介紹,順便對jQuery數組做個總結.溫故,知新.
強烈建議你打開DEMO演示后再看下面的詳解: 點此查看DEMO

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('衛鞅 不存在于數組_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);
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国自在线精品视频| 亚洲人成自拍网站| 97国产精品视频人人做人人爱| 777精品视频| 亚洲欧美日韩精品久久亚洲区| 亚洲福利小视频| 91成人天堂久久成人| 午夜精品久久久久久久久久久久| 欧美成年人视频网站| 久久久免费高清电视剧观看| 亚洲国产精品久久久久久| 成人黄色免费看| 欧美久久精品午夜青青大伊人| 青青久久av北条麻妃黑人| 成人福利网站在线观看| 91av在线播放视频| 亚洲精品成人av| 欧美一区二三区| 两个人的视频www国产精品| 精品久久久久久中文字幕大豆网| 美女黄色丝袜一区| www.色综合| 青青在线视频一区二区三区| 欧美在线视频在线播放完整版免费观看| 欧美激情小视频| 精品视频在线播放| 欧美精品在线视频观看| 不用播放器成人网| 隔壁老王国产在线精品| 久久久亚洲国产天美传媒修理工| 成人在线免费观看视视频| 久久精品成人一区二区三区| 亚洲男人的天堂网站| 欧美自拍大量在线观看| 国产69久久精品成人| 久久777国产线看观看精品| 92版电视剧仙鹤神针在线观看| 在线不卡国产精品| 亚洲欧美三级伦理| 欧美极品美女电影一区| 国产精品成人一区| 国产日韩欧美中文在线播放| 91久久久久久久| 欧美日在线观看| 日韩av在线精品| 国产精品99久久久久久久久| 欧美高清第一页| 欧美日韩国产专区| 精品国产一区二区三区久久久| 国产一区二区三区在线观看视频| 国产视频精品在线| 成人久久精品视频| 91av在线视频观看| 国产成人精品综合| 成人免费视频xnxx.com| 欧美有码在线视频| 不卡av在线网站| 琪琪第一精品导航| 日韩电影中文字幕一区| 在线亚洲午夜片av大片| 日韩中文字幕久久| 久久久久久久一| 国产成人精品综合久久久| 日韩免费在线看| 亚洲国产欧美一区| 国产在线a不卡| 国产国语videosex另类| 91精品久久久久久久久久另类| 国产精品久久久久久久久借妻| 国产亚洲精品va在线观看| 97国产在线观看| 久久视频在线免费观看| 欧美激情一区二区三级高清视频| 亚洲毛片在线免费观看| 久久成人国产精品| 国产激情久久久| 欧美性猛交xxxxx免费看| 亚洲xxxx妇黄裸体| 97在线视频观看| 97国产真实伦对白精彩视频8| 日本一区二区不卡| 久久久久久中文字幕| 欧美最猛性xxxxx亚洲精品| 精品自拍视频在线观看| 国产亚洲一区精品| 日韩av在线网址| 91精品国产成人| 北条麻妃一区二区三区中文字幕| 91精品久久久久久久久久久| 久久久久久91香蕉国产| 国产精品av电影| 日韩电影免费观看在线观看| 欧美激情视频三区| 久久亚洲春色中文字幕| 欧美韩国理论所午夜片917电影| 亚洲欧洲av一区二区| 日本19禁啪啪免费观看www| 亚洲成人av中文字幕| 国产日本欧美视频| 国产成人精品电影久久久| 欧美激情第一页xxx| 美女精品视频一区| 国产一区二区三区日韩欧美| 亚洲理论片在线观看| 久久中文精品视频| 久久国产精品久久久久| 欧美日本亚洲视频| www国产亚洲精品久久网站| 国产成人精品视频在线观看| 岛国精品视频在线播放| 久久精品久久久久久| 亚洲天堂影视av| 日韩精品中文字幕有码专区| 日韩**中文字幕毛片| 日本伊人精品一区二区三区介绍| 日韩欧美一区视频| 亚洲综合在线中文字幕| 91影院在线免费观看视频| 成人激情免费在线| 国产精品观看在线亚洲人成网| 麻豆成人在线看| 久久影院中文字幕| www.xxxx精品| 中文字幕精品www乱入免费视频| 亚洲一区二区在线播放| 久久精品99久久香蕉国产色戒| 日韩不卡在线观看| 狠狠爱在线视频一区| 午夜精品久久久久久久99热浪潮| 国产高清视频一区三区| 久久av资源网站| 国产一区二区三区直播精品电影| 亚洲一区亚洲二区亚洲三区| 中文字幕自拍vr一区二区三区| 日韩中文娱乐网| 欧美华人在线视频| 久久国产精品久久久久久久久久| 97视频在线观看播放| 欧美裸体xxxxx| 欧美午夜丰满在线18影院| 高清日韩电视剧大全免费播放在线观看| 久久久久久久电影一区| 日韩精品中文字幕久久臀| 欧美性猛交xxxx| 国产精品极品尤物在线观看| 欧美视频在线观看 亚洲欧| 欧美性视频在线| 成人免费黄色网| 日韩亚洲精品电影| 欧美激情手机在线视频| 欧美激情乱人伦一区| 国产成人精品在线播放| 欧美亚洲另类制服自拍| 91日本在线观看| 国产精品露脸自拍| 在线激情影院一区| 国产成人综合一区二区三区| 国产在线精品一区免费香蕉| 欧美www在线| 国产一区二区美女视频| 亚洲大尺度美女在线| 91成人国产在线观看| 久久91精品国产91久久跳| 国产a∨精品一区二区三区不卡|