jQuery的each函數詳解及實例
我們知道在JQuery裡,each函數是非常強大的,可以遍歷很多數據,那麼這次就給大家詳細的介紹一下jQuery的each函數的使用方法及實例一份。
$.each()與$(selector).each()不同, 後者專用於jquery物件的遍歷, 前者可用於遍歷任何的集合(無論是數組或物件),如果是數組, 回呼函數每次傳入數組的索引和對應的值(值也可以透過this 關鍵字取得,但javascript總是會包裝this 值作為一個物件—儘管是一個字串或是一個數字) ,方法會回傳被遍歷物件的第一參數.
each()方法能讓DOM迴圈結構簡潔,不容易出錯。 each()函數封裝了十分強大的遍歷功能,使用也很方便,它可以遍歷一維數組、多維數組、DOM, JSON 等等
#在javaScript開發過程中使用$each可以大幅的減輕我們的工作量。
下面提一下each的幾種常用的用法
each處理一維數組
var arr1 = [ "aaa", "bbb", "ccc" ]; $.each(arr1, function(i,val){ alert(i); alert(val); });
alert(i)將輸出0,1,2
alert(val)將輸出aaa,bbb,ccc
each處理二維數組
vararr2 = [['a','aa','aaa'], ['b','bb','bbb'], ['c','cc','ccc']] $.each(arr, function(i, item){ alert(i); alert(item); });
arr2為一個二維數組,item相當於取這二維數組中的每一個數組。
item[0]相對於取每一個一維數組裡的第一個值
alert(i)將輸出為0,1,2,因為這二維數組含有3個陣列元素
alert(item)將輸出為['a', 'aa', 'aaa'],['b', 'bb', 'bbb'],['c', ' cc', 'ccc']
對此二位數組的處理稍作變更之後
var arr = [['a', 'aa', 'aaa'], ['b','bb','bbb'], ['c','cc','ccc']] $.each(arr, function(i, item){ $.each(item,function(j,val){ alert(j); alert(val); }); });
alert(j)將輸出為0,1,2,0,1,2, 0,1,2
alert(val)將輸出為a,aa,aaa,b,bb,bbb,c,cc,ccc
each處理json數據,這個each就有更厲害了,能循環每一個屬性
var obj = { one:1, two:2, three:3}; $.each(obj, function(key, val) { alert(key); alert(val); });
這裡alert(key)將輸出one two three
alert(val)將輸出one,1 ,two,2,three,3
這邊為何key不是數字而是屬性呢,因為json格式內是一組無序的屬性-值,既然無序,又何來數字呢。
而這個val等同於obj[key]
ecah處理dom元素,此處以一個input表單元素作為範例。
如果你dom中有一段這樣的代
然後你使用each如下
$.each($("input:hidden"),function(i,val){ alert(val); alert(i); alert(val.name); alert(val.value); });
那麼,alert(val)會輸出[object HTMLInputElement],因為它是一個表單元素。
alert(i)將輸出為0,1,2,3
alert(val.name);將輸出aaa,bbb,ccc,ddd,如果使用this.name將輸出同樣的結果
alert(val.value); 將輸出111,222,333,444,如果使用this.value將輸出同樣的結果
如果將以上面一段程式碼改變成如下的形式
$("input:hidden").each(function(i,val){ alert(i); alert(val.name); alert(val.value); });
可以看到,輸出的結果是一樣的,至於兩種寫法究竟區別在哪,我也還不知。此改變運用到上面幾段數組的運算也會輸出同樣的結果。
這樣,幾個例子的實際結果已經得到答案。接著再繼續往下研究,總不能知其然不知其所以然。
從以上的例子中可知jQuery和jQuery對像都實現了該方法,對於jQuery對象,只是把each方法簡單的進行了委託:把jQuery對像作為第一個參數傳遞給jQuery的each方法。
看下jQuery中的each實作(網路摘錄)
function (object, callback, args) { //该方法有三个参数:进行操作的对象obj,进行操作的函数fn,函数的参数args var name, i = 0,length = object.length; if (args) { if (length == undefined) { for (name in object) { if (callback.apply(object[name], args) === false) { break; } } } else{ for (; i < length;) { if (callback.apply(object[i++], args) === false) { break; } } } } else{ if (length == undefined) { for (name in object) { if (callback.call(object[name], name, object[name]) === false) { break; } } } else{ for (var value = object[0]; i < length && callback.call(value, i, value) !==false; value = object[++i]) {} /* object[0]取得jQuery对象中的第一个DOM元素,通过for循环, 得到遍历整个jQuery对象中对应的每个DOM元素,通过 callback.call( value,i,value); 将callback的this对象指向value对象,并且传递两个参数,i表示索引值,value表示DOM元素; 其中callback是类似于 function(index, elem) { ... } 的方法。 所以就得到 $("...").each(function(index, elem){ ... }); */ } } return object; }
jquery會自動根據傳入的元素進行判斷,然後在根據判斷結果採取apply還是call方法的處理。在fn的實作中,可以直接採用this指標來引用陣列或是物件的子元素。
1.obj物件是數組
each方法會對數組中子元素的逐個進行fn函數調用,直至調用某個子元素返回的結果為false為止,也就是說,我們可以在提供的fn函數進行處理,使其滿足一定條件後就退出each方法呼叫。當each方法提供了arg參數時,fn函數呼叫傳入的參數為arg,否則為:子元素索引,子元素本身
2.obj 物件不是數組
該方法同1的最大差別是:fn方法會被逐次不考慮回傳值的進行進行。換句話說,obj物件的所有屬性都會被fn方法進行調用,即使fn函數傳回false。呼叫傳入的參數同1類似。
相信看了這些案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!
相關讀取:
#以上是jQuery的each函數詳解及實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

jQuery中如何使用PUT請求方式?在jQuery中,發送PUT請求的方法與發送其他類型的請求類似,但需要注意一些細節和參數設定。 PUT請求通常用於更新資源,例如更新資料庫中的資料或更新伺服器上的檔案。以下是在jQuery中使用PUT請求方式的具體程式碼範例。首先,確保引入了jQuery庫文件,然後可以透過以下方式發送PUT請求:$.ajax({u

標題:jQuery小技巧:快速修改頁面所有a標籤的文字在網頁開發中,我們經常需要對頁面中的元素進行修改和操作。使用jQuery時,有時候需要一次修改頁面中所有a標籤的文字內容,這樣可以節省時間和精力。以下將介紹如何使用jQuery快速修改頁面所有a標籤的文本,同時給出具體的程式碼範例。首先,我們需要引入jQuery庫文件,確保在頁面中引入了以下程式碼:<

jQuery如何移除元素的height屬性?在前端開發中,經常會遇到需要操作元素的高度屬性的需求。有時候,我們可能需要動態改變元素的高度,而有時候又需要移除元素的高度屬性。本文將介紹如何使用jQuery來移除元素的高度屬性,並提供具體的程式碼範例。在使用jQuery操作高度屬性之前,我們首先需要了解CSS中的height屬性。 height屬性用於設定元素的高度

標題:使用jQuery修改所有a標籤的文字內容jQuery是一款受歡迎的JavaScript庫,被廣泛用於處理DOM操作。在網頁開發中,經常會遇到需要修改頁面上連結標籤(a標籤)的文字內容的需求。本文將介紹如何使用jQuery來實現這個目標,並提供具體的程式碼範例。首先,我們需要在頁面中引入jQuery庫。在HTML檔案中加入以下程式碼:

jQuery是一種流行的JavaScript庫,被廣泛用於處理網頁中的DOM操作和事件處理。在jQuery中,eq()方法是用來選擇指定索引位置的元素的方法,具體使用方法和應用場景如下。在jQuery中,eq()方法選擇指定索引位置的元素。索引位置從0開始計數,即第一個元素的索引是0,第二個元素的索引是1,依此類推。 eq()方法的語法如下:$("s

如何判斷jQuery元素是否具有特定屬性?在使用jQuery操作DOM元素時,常會遇到需要判斷元素是否具有某個特定屬性的情況。在這種情況下,我們可以藉助jQuery提供的方法來輕鬆實現這項功能。以下將介紹兩種常用的方法來判斷一個jQuery元素是否具有特定屬性,並附上具體的程式碼範例。方法一:使用attr()方法和typeof運算子//判斷元素是否具有特定屬

jQuery是一個受歡迎的JavaScript函式庫,廣泛用於網頁開發。在網頁開發過程中,經常需要透過JavaScript動態地在表格中新增一行。本文將介紹如何使用jQuery為表格新增一行,並提供具體的程式碼範例。首先,我們需要在HTML頁面中引入jQuery函式庫。可以透過以下程式碼在標籤中引入jQuery庫:

Oracle實例數量與資料庫效能關係Oracle資料庫是業界知名的關係型資料庫管理系統之一,廣泛應用於企業級的資料儲存與管理。在Oracle資料庫中,實例是一個非常重要的概念。實例是指Oracle資料庫在記憶體中的運作環境,每個實例都有獨立的記憶體結構和後台進程,用於處理使用者的請求和管理資料庫的操作。實例數量對於Oracle資料庫的效能和穩定性有著重要的影響。
