each()方法能使DOM循環結構簡潔,不容易出錯。each()函數封裝了十分強大的遍歷功能,使用也很方便,它能夠遍歷一維數組、多維數組、DOM, JSON 等等
在javaScript開發過程當中使用$each能夠大大的減輕咱們的工做量。
下面提一下each的幾種經常使用的用法java
var arr1 = [ "aaa", "bbb", "ccc" ];
$.each(arr1, function(i,val){
alert(i);
alert(val);
});
var arr2 = [['a', 'aa', 'aaa'], ['b', 'bb', 'bbb'], ['c', 'cc', 'ccc']]
$.each(arr, function(i, item){
alert(i);
alert(item);
});
對此二位數組的處理稍做變動以後json
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數組
each處理json數據:dom
這個each就有更厲害了,能循環每個屬性 函數
var obj = { one:1, two:2, three:3};
each(obj, function(key, val) {
alert(key);
alert(val);
});
each處理dom元素:this
此處以一個input表單元素做爲例子。spa
$.each($("input:hidden"), function(i,val){
alert(val);
alert(i);
alert(val.name);
alert(val.value);
});
alert(i)將輸出爲0,1,2,3 code
alert(val.name);將輸出aaa,bbb,ccc,ddd,若是使用this.name將輸出一樣的結果
alert(val.value); 將輸出111,222,333,444,若是使用this.value將輸出一樣的結果blog
若是將以上面一段代碼改變成以下的形式:three
$("input:hidden").each(function(i,val){
alert(i);
alert(val.name);
alert(val.value);
});
能夠看到,輸出的結果是同樣的,至於兩種寫法究竟區別在哪,我也還不知。此改變運用到上面幾段數組的操做也會輸出一樣的結果。