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

首頁 > 編程 > JavaScript > 正文

jquery數組封裝使用方法分享(jquery數組遍歷)

2019-11-20 20:54:49
字體:
來源:轉載
供稿:網友

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

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

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

使用方法如下:

復制代碼 代碼如下:

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);
 // 如果想退出循環
 // return false;
});

再來個測試程序:
[/code]
 var fruit = ['蘋果','香蕉','橙子','哈密瓜','芒果'];
 //用原生getElementsByTagName獲取h2元素的對象集合
 var h2obj=document.getElementsByTagName('h2');

 //$.each()遍歷數組
 $('input#js_each').click(function(){
  $.each(fruit,function(key,val){
   //回調函數有兩個參數,第一個是元素索引,第二個為當前值
   alert('fruit數組中,索引:'+key+'對應的值為:'+val);
  });
 });

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

$.grep(array, callback, [invert])過濾

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

復制代碼 代碼如下:

v[code]ar temp = [];
temp = $.grep(arr, function(val, key) {
 if(val.indexOf('c') != -1)
  return true;
 // 如果[invert]參數不給或為false, $.grep只收集回調函數返回true的數組元素
 // 反之[invert]參數為true, $.grep收集回調函數返回false的數組元素
}, false);
console.dir(temp);

再來個測試程序:

復制代碼 代碼如下:

 //$.grep()過濾數組
 $('input#js_grep').click(function(){
  $.grep(fruit,function(val,key){
   //過濾函數有兩個參數,第一個為當前元素,第二個為元素索引
   if(val=='芒果'){
    alert('數組值為 芒果 的下標是: '+key);
   }
  });

  var _moziGt1=$.grep(fruit,function(val,key){
   return key>1;
  });
  alert('fruit數組中索引值大于1的元素為: '+_moziGt1);

  var _moziLt1=$.grep(fruit,function(val,key){
   return key>1;
  },true);
  //此處傳入了第三個可靠參數,對過濾函數中的返回值取反
  alert('fruit數組中索引值小于等于1的元素為: '+_moziLt1);
 });

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

作為參數的轉換函數會為每個數組元素調用, 而且會給這個轉換函數傳遞一個表示被轉換的元素作為參數. 轉換函數可以返回轉換后的值、null(刪除數組中的項目)或一個包含值的數組, 并擴展至原始數組中.這個是個很強大的方法,但并不常用. 它可以根據特定條件,更新數組元素值,或根據原值擴展一個新的副本元素.

復制代碼 代碼如下:

//1.6之前的版本只支持數組
temp = $.map(arr, function(val, key) {
 //返回null,返回的數組長度減1
 if(val === 'vb') return null;
 return val;
});
console.dir(temp);
//1.6開始支持json格式的object
var obj = {key1: 'val1', key2: 'val2', key3: 'val3'};
temp = $.map(obj, function(val, key) {
 return val;
});
console.dir(temp);

再來個測試程序:

復制代碼 代碼如下:

 //$.map()按給定條件轉換數組
 $('input#js_map').click(function(){
  var _mapArrA=$.map(fruit,function(val){
   return val+'[新加]';
  });
  var _mapArrB=$.map(fruit,function(val){
   return val=='蘋果' ? '[只給蘋果加]'+val : val;
  });
  var _mapArrC=$.map(fruit,function(val){
   //為數組元素擴展一個新元素
   return [val,(val+'[擴展]')];
  });
  alert('在每個元素后面加/'[新加]/'字符后的數組為: '+ _mapArrA);
  alert('只給元素 蘋果 添加字符后的數組為: '+ _mapArrB);
  alert('為原數組中每個元素,擴展一個添加字符/'[新加]/'的元素,返回的數組為 '+_mapArrC);
 });

$.inArray(val,array)判斷值是否存在于數組中

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

復制代碼 代碼如下:

//返回元素在數組中的位置,0為起始位置,返回-1則未找到該元素
console.log($.inArray('javascript', arr));


測試程序:
[code]
 //$.inArray判斷值是否在數組中,不存在返回-1,存在則返回對應索引值
 $('input#js_inarray').click(function(){
  var _exist=$.inArray('芒果',fruit);
  var _inexistence=$.inArray('榴蓮',fruit)
  if(_exist>=0){
   alert('芒果 存在于數組fruit中,其在數組中索引值是: '+_exist);
  }
  if(_inexistence< 0){
   alert('榴蓮 不存在于數組fruit中!,返回值為: '+_inexistence+'!');
  }
 });

$.merge(first,second)合并兩個數組

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

復制代碼 代碼如下:

var frontEnd = ['javascript', 'css', 'html'],
   backEnd = ['java', 'php', 'c++'];
// 這種方式會修改第一個參數, 即frontEnd數組
temp = $.merge(frontEnd, backEnd);
console.dir(temp);
console.dir(frontEnd);
// 可以用下面的方式來避免對原數組的影響
// $.merge($.merge([], frontEnd), backEnd);

測試程序

復制代碼 代碼如下:

 //$.merge()合并兩個數組
 $('input#js_merge').click(function(){
  //原生concat()可能比它還簡潔點
  fruitNew=$.merge(fruit,['水蜜桃','火龍果','西瓜','楊桃','荔枝','龍眼'])
  alert('合并后新數組長度為: '+fruitNew.length+'. 其值為: '+fruitNew);
 });

$.unique(array)過濾數組中重復元素

刪除數組中重復元素. 只處理刪除DOM元素數組,而不能處理字符串或者數字數組.第一次看到這個方法,覺得這是個很便捷的方法, 可以過濾重復, 哈, 多完美, 但仔細一看, 僅限處理DOM元素. 功能8折了.所以, 我給它定義成了一個不常用的元素, 至少, 我用jQuery以來沒用到過它.

復制代碼 代碼如下:

<div>blahblahblah....</div>
<div></div>
<div class="dup"></div>
<div class="dup"></div>
<div class="dup"></div>
<div></div>
// $.unique只支持DOM元素數組,去除重復DOM元素,不支持其他類型數組(String或者Number)
// 獲得原始的DOM數組,而不是jQuery封裝的
var divs = $('div').get();
// 增加幾個class為dup的div
divs = divs.concat($('div.dup').get());
console.log("before unique:" + divs.length);
divs = $.unique(divs);
console.log("after unique:" + divs.length);

測試程序:

復制代碼 代碼如下:

 //$.unique()過濾數組中重復元素(僅限DOM元素數組)
 $('input#js_unique').click(function(){
  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)+'個重復元素');
 });

$.makeArray(obj) 將類數組對象轉換為數組

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

首先什么是類數組對象?jQuery官網上用divs = getElementsByTag('div')來做例子,這個divs有類似數組的一些方法比如length,通過[index]方式獲取元素等,然后通過$.makeArray(divs)使它轉為數組,就可以用數組的其他功能,比如reverse(), pop()等。

復制代碼 代碼如下:

 //$.makeArr()類數組轉換
 $('input#js_makearray').click(function(){
  var _makeArr=$.makeArray(h2obj);
  alert('h2元素對象集合的數據類型轉換為: '+_makeArr.constructor.name);
 });

$(dom).toArray()將所有DOM元素恢復成數組

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

復制代碼 代碼如下:

 //$(dom).toArray()將所有DOM元素恢復成數組
 $('input#js_toarray').click(function(){
  var _toArr=$('h2').toArray();
  alert('h2元素集合恢復后的數據類型是: '+_toArr.constructor.name);

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产日韩欧美另类| 清纯唯美日韩制服另类| 91色中文字幕| 欧美电影免费观看高清完整| 亚洲欧洲第一视频| 欧美激情奇米色| 精品日韩视频在线观看| 欧美精品久久久久久久| 欧美日本国产在线| 久久免费国产精品1| 欧美激情第一页xxx| 亚洲第一中文字幕在线观看| 日韩av免费在线观看| 国外成人在线视频| 日韩欧美在线国产| 色综合91久久精品中文字幕| 日韩国产激情在线| 日韩美女免费线视频| 欧美精品激情在线| 欧美日韩亚洲一区二区三区| 亚洲高清一区二| 成人黄色大片在线免费观看| 大量国产精品视频| 奇米成人av国产一区二区三区| 亚洲国产成人久久综合| 在线观看视频亚洲| 国产亚洲欧美另类中文| 黑人巨大精品欧美一区二区| 国产精品午夜一区二区欲梦| 欧美性猛交xxxx免费看| 精品国产一区二区三区在线观看| 久久99久久亚洲国产| 国内精品久久久久影院 日本资源| 国产精品欧美日韩一区二区| 久久精品2019中文字幕| 国产精品高潮呻吟久久av黑人| 国产精品pans私拍| 亚洲女人初尝黑人巨大| 国产精品手机播放| 欧美诱惑福利视频| 欧美一级片免费在线| 91国语精品自产拍在线观看性色| 国产精品极品美女粉嫩高清在线| 日韩av手机在线看| 久久久久久久久久久免费| 中文字幕成人精品久久不卡| 亚洲欧美日韩久久久久久| 国产主播在线一区| 午夜欧美大片免费观看| 欧美激情视频一区| 91黄色8090| 国产一区二区久久精品| 日韩欧美主播在线| 国产小视频91| 亚洲白虎美女被爆操| 欧美精品中文字幕一区| 久久婷婷国产麻豆91天堂| 热久久99这里有精品| 欧美日韩国产中文字幕| 欧美猛交ⅹxxx乱大交视频| 欧美激情手机在线视频| 中文字幕日韩免费视频| 国产一区二区三区高清在线观看| 91成人天堂久久成人| 久久久之久亚州精品露出| 日韩国产中文字幕| 久久久久久久网站| 日韩中文字幕在线免费观看| www.午夜精品| 久久中文字幕一区| 欧美日韩一区二区免费视频| 久久久伊人欧美| 久久精品成人欧美大片古装| 欧美日韩国产999| 欧美日韩国产丝袜美女| 日韩精品中文字幕有码专区| 亚洲精品国产精品久久清纯直播| 欧美在线亚洲一区| 98午夜经典影视| 最近2019好看的中文字幕免费| xxav国产精品美女主播| 黑人巨大精品欧美一区二区一视频| 亚洲精品国产品国语在线| 久久人人爽人人爽爽久久| 色婷婷综合久久久久中文字幕1| www.亚洲男人天堂| 亚洲色图25p| 国产精品福利久久久| 欧美亚洲在线观看| 日韩亚洲一区二区| 欧美一区二区三区精品电影| 97成人精品视频在线观看| 成人国产精品色哟哟| 日韩av手机在线看| 国产香蕉精品视频一区二区三区| 国产精品久久久久久影视| 亚洲欧美国产一区二区三区| 欧美一乱一性一交一视频| 久久影视电视剧免费网站| 欧美性猛交xxxx乱大交3| 国产精品高潮呻吟视频| 成人性生交xxxxx网站| 亚洲成人aaa| 国产欧美一区二区三区久久| 久久成人在线视频| 久久久久久国产精品三级玉女聊斋| 国内精品小视频在线观看| 国产欧美最新羞羞视频在线观看| 91网站在线免费观看| 国产欧美一区二区三区在线| 欧美一区三区三区高中清蜜桃| 色琪琪综合男人的天堂aⅴ视频| y97精品国产97久久久久久| 国产美女主播一区| 亚洲国产精品国自产拍av秋霞| 精品久久久中文| 精品国内亚洲在观看18黄| 国产mv免费观看入口亚洲| 91手机视频在线观看| 亚洲精品福利在线观看| 国产精品扒开腿做| 欧美激情一区二区三区在线视频观看| 欧美xxxx18性欧美| 中文综合在线观看| 91在线观看免费高清完整版在线观看| 777精品视频| 在线成人激情视频| 国产精品久久久久久亚洲影视| 精品久久久在线观看| 日韩欧美第一页| 欧美影院成年免费版| 国产日韩欧美视频在线| 91在线观看免费高清完整版在线观看| 亚洲天堂免费视频| 日韩精品中文字幕视频在线| 国产精品久久久久久亚洲调教| 国产精品久久久久久亚洲调教| 久热精品在线视频| 日韩在线观看免费高清完整版| 国产精品第一区| 色多多国产成人永久免费网站| 亚洲欧美成人一区二区在线电影| 国产专区精品视频| 亚洲欧美视频在线| 亚洲国产精品yw在线观看| 亚洲成人久久一区| 欧美资源在线观看| 97精品国产91久久久久久| 国语自产精品视频在线看| 日韩高清a**址| 狠狠色狠色综合曰曰| 亚洲无亚洲人成网站77777| 欧美性猛交99久久久久99按摩| 91欧美日韩一区| 日韩av影视综合网| 久久久久久久久国产精品| 蜜臀久久99精品久久久无需会员| 亚洲欧美日韩中文在线制服| 国产日韩av在线| 日韩成人黄色av| 国产又爽又黄的激情精品视频| 26uuu久久噜噜噜噜| 国产精品成av人在线视午夜片| 一区二区福利视频|