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

首頁 > 編程 > JavaScript > 正文

jquery基礎教程之數組使用詳解

2019-11-20 20:57:45
字體:
來源:轉載
供稿:網友

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
欧美激情亚洲国产| 成人妇女免费播放久久久| 亚洲国产成人av在线| 亚洲成人教育av| 欧美电影第一页| 成人精品一区二区三区| 亚洲精品免费在线视频| 亚洲一区二区久久| 国产有码一区二区| 日本久久精品视频| 欧美在线观看网址综合| 欧美日韩精品二区| 久久久国产精品免费| 久久香蕉精品香蕉| 日韩精品极品毛片系列视频| 欧美亚洲日本网站| 国产精品com| 97视频免费在线看| 亚洲美女精品成人在线视频| 国语自产偷拍精品视频偷| 欧美日韩国产一区二区| 色诱女教师一区二区三区| 在线播放日韩欧美| 欧美大全免费观看电视剧大泉洋| 久久久久久高潮国产精品视| 国产精品v片在线观看不卡| 色偷偷噜噜噜亚洲男人| 美女av一区二区三区| 欧美高清视频免费观看| 操91在线视频| 视频直播国产精品| 91性高湖久久久久久久久_久久99| 久久久国产精品视频| 亚洲人成免费电影| 亚洲欧美资源在线| 国产成人亚洲综合青青| 国产日韩欧美日韩| 91在线视频九色| 亚洲伊人成综合成人网| 色狠狠久久aa北条麻妃| 日韩av中文在线| 国产91在线高潮白浆在线观看| 国产91久久婷婷一区二区| 久久人91精品久久久久久不卡| 欧美午夜宅男影院在线观看| 国产一区欧美二区三区| 亚洲综合中文字幕在线观看| 日韩欧美大尺度| 国产精品偷伦一区二区| 九色精品美女在线| 91欧美精品成人综合在线观看| 亚洲视频在线观看| 亚洲国产精品专区久久| 国产成人激情小视频| 欧洲s码亚洲m码精品一区| 亚洲精品福利在线观看| 欧美在线视频免费播放| 欧美大尺度电影在线观看| 欧美在线xxx| 欧美日韩亚洲一区二区三区| 97av视频在线| 91丝袜美腿美女视频网站| 日本道色综合久久影院| 亚洲精品一区久久久久久| 国模精品系列视频| 欧美夜福利tv在线| 欧美成人免费一级人片100| 久久精品91久久香蕉加勒比| 欧美在线一区二区视频| 亚洲精品电影网站| 91视频免费网站| 欧洲美女7788成人免费视频| 亚洲欧美日韩中文在线制服| 97国产一区二区精品久久呦| 国产美女久久久| 亚洲视频一区二区三区| 亚洲国产精品va| 国产成人精品电影久久久| 欧美日韩国产限制| 亚洲福利视频网站| 欧美性猛交xxx| 人九九综合九九宗合| 欧美电影电视剧在线观看| 91久久嫩草影院一区二区| 亚洲香蕉成人av网站在线观看| 日韩黄色av网站| 欧美日韩精品在线播放| 午夜精品理论片| 色yeye香蕉凹凸一区二区av| 国产精品成熟老女人| 色系列之999| 国产精品久久久久久超碰| 亚洲一区二区三区xxx视频| 亚洲偷欧美偷国内偷| 国产精品美女www| 日韩在线观看免费全集电视剧网站| 亚洲在线免费看| 国产成人精品一区| 成人精品视频99在线观看免费| 久久人人爽亚洲精品天堂| y97精品国产97久久久久久| 日韩成人网免费视频| 亚洲精选一区二区| 色香阁99久久精品久久久| 色偷偷9999www| 欧美精品一区二区免费| 久久成人精品一区二区三区| 伦伦影院午夜日韩欧美限制| 久久精品视频播放| 国产精品一区二区在线| 日韩精品免费综合视频在线播放| 国模极品一区二区三区| 中文字幕亚洲情99在线| 日韩福利伦理影院免费| 日韩最新av在线| 亚洲国产女人aaa毛片在线| 日韩在线观看视频免费| 国产日韩欧美自拍| 日本在线观看天堂男亚洲| 亚洲第一精品电影| 日韩二区三区在线| wwwwwwww亚洲| 日韩视频免费在线观看| 日韩在线观看成人| 亚洲片在线资源| 中文字幕v亚洲ⅴv天堂| 欧美国产乱视频| 一区二区三欧美| 日韩电影免费在线观看中文字幕| 欧美最顶级的aⅴ艳星| 欧美性视频网站| 欧美视频一二三| 久久久久久久av| 欧美日韩免费网站| 亚洲国产精品嫩草影院久久| 日韩av网站在线| 欧美激情第三页| 成人午夜在线视频一区| 88xx成人精品| 国产精品情侣自拍| 日韩高清av在线| 亚洲精品国产精品自产a区红杏吧| 久久久久久久国产精品视频| 国产精品视频精品| 欧美最顶级的aⅴ艳星| 日韩视频免费看| 久久手机免费视频| 97视频在线免费观看| 欧美精品久久久久久久| 成人国产精品一区| 2025国产精品视频| 国产成人亚洲综合91精品| 亚洲电影中文字幕| 国内精品伊人久久| 欧美成人在线免费| 欧美大片在线看免费观看| 成人免费视频网址| 国产精品久久久久久久久久免费| 伊人亚洲福利一区二区三区| 亚洲精品电影网站| 日韩av手机在线看| 欧美香蕉大胸在线视频观看| 久久国产精品电影| **欧美日韩vr在线|