麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

jquery基礎(chǔ)教程之?dāng)?shù)組使用詳解

2019-11-20 20:57:45
字體:
供稿:網(wǎng)友

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

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

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

復(fù)制代碼 代碼如下:

var _mozi=['墨家','墨子','墨翟','兼愛非攻','尚同尚賢']; //本文所用到的數(shù)組, 下同 
$.each(_mozi,function(key,val){ 
    //回調(diào)函數(shù)有兩個參數(shù),第一個是元素索引,第二個為當(dāng)前值 
    alert('_mozi數(shù)組中 ,索引 : '+key+' 對應(yīng)的值為: '+val); 
});

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

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

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

復(fù)制代碼 代碼如下:

$.grep(_mozi,function(val,key){ 
    //過濾函數(shù)有兩個參數(shù),第一個為當(dāng)前元素,第二個為元素索引 
    if(val=='墨子'){ 
        alert('數(shù)組值為 墨子 的下標(biāo)是: '+key); 
    } 
}); 

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

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

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

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

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

復(fù)制代碼 代碼如下:

var _mapArrA=$.map(_mozi,function(val){ 
    return val+'[新加]'; 
}); 
var _mapArrB=$.map(_mozi,function(val){ 
    return val=='墨子' ? '[只給墨子加]'+val : val; 
}); 
var _mapArrC=$.map(_mozi,function(val){ 
    //為數(shù)組元素擴展一個新元素 
    return [val,(val+'[擴展]')]; 
}); 
alert('在每個元素后面加/'[新加]/'字符后的數(shù)組為: '+ _mapArrA); 
alert('只給元素 墨子 添加字符后的數(shù)組為: '+ _mapArrB); 
alert('為原數(shù)組中每個元素,擴展一個添加字符/'[新加]/'的元素,返回的數(shù)組為 '+_mapArrC);

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

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

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

復(fù)制代碼 代碼如下:

var _exist=$.inArray('墨子',_mozi); 
var _inexistence=$.inArray('衛(wèi)鞅',_mozi) 
if(_exist>=0){ 
    alert('墨子 存在于數(shù)組_mozi中,其在數(shù)組中索引值是: '+_exist); 

if(_inexistence<0){ 
    alert('衛(wèi)鞅 不存在于數(shù)組_mozi中!,返回值為: '+_inexistence+'!'); 
}

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

 

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

復(fù)制代碼 代碼如下:

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

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

 

解釋: 刪除數(shù)組中重復(fù)元素. 只處理刪除DOM元素數(shù)組,而不能處理字符串或者數(shù)字?jǐn)?shù)組。

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

復(fù)制代碼 代碼如下:

var _h2Arr=$.makeArray(h2obj); 
//將數(shù)組_h2Arr重復(fù)一次 
_h2Arr=$.merge(_h2Arr,_h2Arr); 
var _curLen=_h2Arr.length; 
_h2Arr=$.unique(_h2Arr); 
var _newLen=_h2Arr.length; 
alert('數(shù)組_h2Arr原長度值為: '+_curLen+' ,過濾后為: '+_newLen 
      +' .共過濾 '+(_curLen-_newLen)+'個重復(fù)元素')

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

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

復(fù)制代碼 代碼如下:

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

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

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

復(fù)制代碼 代碼如下:

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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 亚洲特黄妇女高潮 | 日本不卡一区二区三区在线 | 日韩视频一区二区三区四区 | 19禁国产精品福利视频 | 亚洲成人夜色 | 欧美a黄 | 国产一级一片免费播放 | 国产免费一级淫片a级中文 99国产精品自拍 | 欧美扩阴视频 | 久久思思爱 | 妇女毛片 | av在线免费观看不卡 | 日韩av在线网址 | 在线观看免费视频麻豆 | 日韩大片在线永久观看视频网站免费 | 精品一区二区三区中文字幕老牛 | 免费黄色小网站 | 毛片免费看的 | 免费一及片 | 高清国产午夜精品久久久久久 | 亚洲一级片在线观看 | 日韩一级片一区二区三区 | 亚洲网站免费观看 | 久草干 | 日本黄色免费播放 | 黄色成人小视频 | 国产成人在线观看免费网站 | 99麻豆久久久国产精品免费 | 欧美三级欧美成人高清www | 精品一区二区视频在线观看 | 老子午夜影院 | 全黄裸片武则天一级第4季 偿还电影免费看 | 91九色论坛 | 吾色视频 | 日朝毛片| 视屏一区 | 一级大黄毛片免费观看 | 午夜a狂野欧美一区二区 | 欧洲精品久久久 | 国产一级一国产一级毛片 | 毛片在线视频观看 |