以下内容非本人原创,来自百度文库,相关参考资源地址如下:
http://wenku.baidu.com/view/4796b6145f0e7cd18425368e.html
http://jingyan.baidu.com/article/948f592402b771d80ef5f960.html
通过它,你可以遍历对象、数组的属性值并进行处理。
使用说明
each函数根据参数的类型实现的效果不完全一致:
1、遍历对象(有附加参数)
$.each(Object, function(p1, p2) {
this; //这里的this指向每次遍历中Object的当前属性值
p1; p2; //访问附加参数
}, ['参数1', '参数2']);
2、遍历数组(有附件参数)
$.each(Array, function(p1, p2){
this; //这里的this指向每次遍历中Array的当前元素
p1; p2; //访问附加参数
}, ['参数1', '参数2']);
3、遍历对象(没有附加参数)
$.each(Object, function(name, value) {
this; //this指向当前属性的值
name; //name表示Object当前属性的名称
value; //value表示Object当前属性的值
});
4、遍历数组(没有附加参数)
$.each(Array, function(i, value) {
this; //this指向当前元素
i; //i表示Array当前下标
value; //value表示Array当前元素
});
下面提一下jQuery的each方法的几种常用的用法
Js代码
var arr = [ "one", "two", "three", "four"];
$.each(arr, function(){
alert(this);
});
//上面这个each输出的结果分别为:one,two,three,four
var arr1 = [[1, 4, 3], [4, 6, 6], [7, 20, 9]]
$.each(arr1, function(i, item){
alert(item[0]);
});
//其实arr1为一个二维数组,item相当于取每一个一维数组,
//item[0]相对于取每一个一维数组里的第一个值
//所以上面这个each输出分别为:1 4 7
var obj = { one:1, two:2, three:3, four:4};
$.each(obj, function(key, val) {
alert(obj[key]);
});
//这个each就有更厉害了,能循环每一个属性
//输出结果为:1 2 3 4
**************************************************************************
-
可以遍历一个变量,如:数组
var hotel= ['a','b','c'];
$.each(hotel, function(i) {
alert(hotel[i]);
});
-
也可以遍历界面元素
例如,一个界面中有多个图片,我们想要遍历所有<img>元素取出它们的图片地址,可以像下面这样做
$("img").each(function(i){ alert(this.src); });//this指代当前循环到的img元素
当然我们也可以动态给<img>元素指定图片地址
$("img").each(function(i){
this.src = "test" + i + ".jpg";
});
如果想要实现在某一条件下推出遍历,可以使用return
var arr= [1,2,3,4,5];
$.each(hotel, function(i) {
if(arr[i]>2){return;}
});