jQuery中常用的遍历函数用法实例总结
本文实例总结了jQuery中常用的遍历函数用法。分享给大家供大家参考。具体如下:
1.children()函数
children()函数用于选取每个匹配元素的子元素,并以jQuery对象的形式返回。
你还可以使用选择器进一步缩小筛选范围,筛选出符合指定选择器的元素。
用法示例如下:
//返回jQuery对象所有匹配元素的标识信息数组
//每个元素形如:tagName或tagName#id(如果有id的话)
functiongetTagsInfo($doms){
return$doms.map(function(){
returnthis.tagName+(this.id?"#"+this.id:"");
}).get();
}
//匹配id为n1的元素
var$n1=$("#n1");
//匹配n1的所有子元素
var$menu_li=$n1.children();
document.writeln(getTagsInfo($menu_li));//LI#n2,LI#n7,LI#n13
//匹配n1所有含有类名active的子元素
var$active_menu_li=$n1.children(".active");
document.writeln(getTagsInfo($active_menu_li));//LI#n2
//匹配$menu_li每个元素的所有span子元素
var$span=$menu_li.children("span");
document.writeln(getTagsInfo($span));//SPAN#n3,SPAN#n8,SPAN#n14
2.filter()函数
filter()函数用于筛选出符合指定表达式的元素,并以jQuery对象的形式返回。
这里的表达式包括:选择器(字符串)、DOM元素(Element)、jQuery对象、函数。
用法示例如下:
/*$("li")匹配n4、n5、n6这3个元素*/
//筛选出所有索引为偶数(序号为奇数)的元素,即n4、n6
document.writeln($("li").filter(":even").length);//2
//筛选出包含类名foo的元素,即n5
document.writeln($("li").filter($(".foo")).length);//1
//筛选出所有带有class属性的元素,即n5、n6
document.writeln($("li").filter("[class]").length);//2
/*$("input")匹配n8、n9这两个元素*/
//筛选出选中的元素,即n9
document.writeln($("input").filter(":checked").length);//1
varinput=document.getElementsByName("codeplayer");
//筛选出所有的input元素,即n8、n9
document.writeln($("input").filter(input).length);//2
//$("div")匹配n1、n2、n7这3个元素
//筛选出id和class属性相等的元素,即n2、n7
var$result=$("div").filter(function(index,element){
//函数内的this===element
returnthis.id==this.className;
});
document.writeln($result.length);//2
3.not()函数
not()函数用于从匹配元素中删除符合指定表达式的元素,并以jQuery对象的形式返回保留的元素。
这里的表达式包括:选择器(字符串)、DOM元素(Element)、jQuery对象、函数。
与该函数相对的是add()函数,用于向当前匹配元素中添加符合指定表达式的元素。
用法示例如下:
/*$("li")匹配n4、n5、n6这3个元素*/
//排除掉n6,剩下2个元素n4、n5
document.writeln($("li").not("#n6").length);//2
//排除掉带类名foo的元素,剩下n4、n6
document.writeln($("li").not($(".foo")).length);//2
//排除掉所有带有class属性的元素,剩下n4
document.writeln($("li").not("[class]").length);//1
/*$("input")匹配n8、n9这两个元素*/
//排除掉被选中的元素,剩下n8
document.writeln($("input").not(":checked").length);//1
varinput=document.getElementsByTagName("input");
//排除掉所有input元素,返回空的jQuery对象
document.writeln($("input").not(input).length);//0
/*$("div")匹配n1、n2、n7这3个元素*/
//排除掉id和class属性相等的元素,剩下n1
var$result=$("div").not(function(index,element){
//函数内的this===element
returnthis.id==this.className;
});
document.writeln($result.length);//1
4.add()函数
add()函数用于向当前匹配元素中添加符合指定表达式的元素,并以jQuery对象的形式返回。
这里的表达式包括:选择器(字符串)、HTML内容(字符串)、DOM元素(Element)、jQuery对象。
与该函数相对的是not()函数,用于从当前匹配元素中移除符合指定表达式的元素。
用法示例如下:
//返回jQuery对象所有匹配元素的标识信息数组
//每个元素形如:#id
functiongetTagsInfo($doms){
return$doms.map(function(){
return"#"+this.id;
}).get();
}
//匹配所有的p元素,再加上所有的label元素
var$elements1=$("p").add("label");
document.writeln(getTagsInfo($elements1));//#n1,#n4,#n9,#n11
var$matches=$("span.active").add(document.getElementsByTagName("label"));
document.writeln(getTagsInfo($matches));//#n4,#n8,#n11,#n12
var$elements2=$("label").add($("strong"));
document.writeln(getTagsInfo($elements2));//#n4,#n7,#n11
var$elements3=$("span.active").add("label",$("#n9"));
document.writeln(getTagsInfo($elements3));//#n8,#n11,#n12
var$elements4=$("p").add(".active").add("span:only-child");
document.writeln(getTagsInfo($elements4));//#n1,#n3,#n6,#n7,#n8,#n9,#n12
5.slice()函数
slice()函数用于选取匹配元素中一段连续的元素,并以jQuery对象的形式返回。
该函数属于jQuery对象(实例)。
用法示例如下:
//返回jQuery对象所有匹配元素的标识信息数组
//每个元素形如:tagName或tagName#id(如果有id的话)
functiongetTagsInfo($doms){
return$doms.map(function(){
returnthis.tagName+(this.id?"#"+this.id:"");
}).get();
}
/*$("li")匹配n4、n5、n6、n7、n8这5个元素*/
var$li=$("li");
//选取第2个元素
var$sub1=$("li").slice(1,2);
document.writeln(getTagsInfo($sub1));//LI#n5
//选取第4、5个元素
var$sub2=$("li").slice(3);
document.writeln(getTagsInfo($sub2));//LI#n7,LI#n8
//选取第1~4个元素
//startIndex=length+(-5)=0,endIndex=length+(-1)=4
var$sub3=$("li").slice(-5,-1);
document.writeln(getTagsInfo($sub3));//LI#n4,LI#n5,LI#n6,LI#n7
6.parent()函数
parent()函数用于选取每个匹配元素的父元素,并以jQuery对象的形式返回。
你还可以使用选择器来进一步缩小选取范围,筛选出符合指定选择器的元素。
该函数属于jQuery对象(实例)。
用法示例如下:
//返回jQuery对象所有匹配元素的标识信息数组
//每个元素形如:tagName或tagName#id(如果有id的话)
functiongetTagsInfo($doms){
return$doms.map(function(){
returnthis.tagName+(this.id?"#"+this.id:"");
}).get();
}
var$n2=$("#n2");
//获取n2的父元素
var$parents1=$n2.parent();
document.writeln(getTagsInfo($parents1));//DIV#n1
var$p=$("p");
//获取所有p元素的父元素
var$parents2=$p.parent();
document.writeln(getTagsInfo($parents2));//DIV#n1,DIV#n5
//获取所有p元素的包含类名"bar"的父元素
var$parents3=$p.parent(".bar");
document.writeln(getTagsInfo($parents3));//DIV#n5
var$foo=$(".foo");
//获取所有包含类名"foo"的元素的父元素
var$parents4=$foo.parent();
document.writeln(getTagsInfo($parents4));//P#n3,DIV#n5
7.parents()函数
parents()函数用于选取每个匹配元素的祖先元素,并以jQuery对象的形式返回。
你还可以使用选择器来进一步缩小选取范围,只选取其中符合指定选择器的元素。
该函数属于jQuery对象(实例)。
用法示例如下:
//返回jQuery对象所有匹配元素的标识信息数组
//每个元素形如:tagName或tagName#id(如果有id的话)
functiongetTagsInfo($doms){
return$doms.map(function(){
returnthis.tagName+(this.id?"#"+this.id:"");
}).get();
}
var$n4=$("#n4");
//获取n4的祖先元素
var$parents1=$n4.parents();
document.writeln(getTagsInfo($parents1));//P#n3,DIV#n1,BODY,HTML
var$p=$("p");
//获取所有p元素的祖先元素
var$parents2=$p.parents();
document.writeln(getTagsInfo($parents2));//DIV#n5,DIV#n1,BODY,HTML
//获取所有p元素的包含类名"bar"的祖先元素
var$parents3=$p.parents(".bar");
document.writeln(getTagsInfo($parents3));//DIV#n5
var$foo=$(".foo");
//获取所有包含类名"foo"的元素的祖先元素中的div元素
var$parents4=$foo.parents("div");
document.writeln(getTagsInfo($parents4));//DIV#n5,DIV#n1
8.siblings()函数
siblings()函数用于选取每个匹配元素的所有同辈元素(不包括自己),并以jQuery对象的形式返回。
你还可以使用选择器来进一步缩小选取范围,筛选出符合指定选择器的元素。
该函数属于jQuery对象(实例)。
用法示例如下:
//返回jQuery对象所有匹配元素的标识信息数组
//每个元素形如:#id
functiongetTagsInfo($doms){
return$doms.map(function(){
return"#"+this.id;
}).get();
}
var$n4=$("#n4");
//匹配n4的所有同辈元素(同辈元素不会包括n4自己,下同)
var$elements=$n4.siblings();
document.writeln(getTagsInfo($elements));//#n2,#n5,#n7,#n8
//匹配n4所有的同辈span元素
var$matches=$n4.siblings("span");
document.writeln(getTagsInfo($matches));//#n2,#n5,#n8
var$label=$("label");
//匹配所有label元素的含有类名"active"的同辈元素
var$actives=$label.siblings(".active");
document.writeln(getTagsInfo($actives));//#n7,#n8,#n12
9.prev()与prevAll()函数
prev()函数用于筛选每个匹配元素之前紧邻的同辈元素,并以jQuery对象的形式返回。
你还可以使用指定的选择器进一步缩小筛选范围,筛选出符合指定选择器的元素。
与该函数相对的是next()函数,用于筛选每个匹配元素之后紧邻的同辈元素。
prevAll()函数用于选取每个匹配元素之前的所有同辈元素,并以jQuery对象的形式返回。
你还可以使用选择器来进一步缩小选取范围,筛选出符合指定选择器的元素。
与该函数相对的是nextAll()函数,用于选取每个匹配元素之后的所有同辈元素。
prev()用法示例如下:
//返回jQuery对象所有匹配元素的标识信息数组
//每个元素形如:tagName或tagName#id(如果有id的话)
functiongetTagsInfo($doms){
return$doms.map(function(){
returnthis.tagName+(this.id?"#"+this.id:"");
}).get();
}
//匹配所有span元素:e2、e3、e4、e5、e7、e9
var$span=$("span");
//匹配所有span元素之前紧邻的同辈元素:e3、e2、e8
//e2=>无【没有上一个紧邻的同辈元素,因为它是同辈元素中的第一个,下同】
//e3=>无
//e4=>e3
//e5=>e2
//e7=>无
//e9=>e8
var$span_prev=$span.prev();
document.writeln(getTagsInfo($span_prev));//SPAN#e3,SPAN#e2,A#e8
//匹配所有span元素之前紧邻的同辈span元素
var$span_prev_span=$span.prev("span");
document.writeln(getTagsInfo($span_prev_span));//SPAN#e3,SPAN#e2
prevAll()用法示例如下:
//返回jQuery对象所有匹配元素的标识信息数组
//每个元素形如:#id
functiongetTagsInfo($doms){
return$doms.map(function(){
return"#"+this.id;
}).get();
}
var$n6=$("#n6");
//匹配n6之前所有的同辈元素
var$n6_prevAll=$n6.prevAll();
document.writeln(getTagsInfo($n6_prevAll));//#n5,#n4,#n2
//匹配n6之前的所有同辈strong元素
var$n6_prevAll_strong=$n6.prevAll("strong");
document.writeln(getTagsInfo($n6_prevAll_strong));//#n4
var$label=$("label");
//匹配所有label元素之前的包含类名"active"的同辈元素
var$label_prevAll_active=$label.prevAll(".active");
document.writeln(getTagsInfo($label_prevAll_active));//#n10,#n5,#n4
10.next()函数与nextAll()函数
next()函数用于筛选每个匹配元素之后紧邻的同辈元素,并以jQuery对象的形式返回。
你还可以使用指定的选择器进一步缩小筛选范围,筛选出符合指定选择器的元素。
与该函数相对的是prev()函数,用于筛选每个匹配元素之前紧邻的同辈元素。
nextAll()函数用于选取每个匹配元素之后的所有同辈元素,并以jQuery对象的形式返回。
你还可以使用选择器来进一步缩小选取范围,筛选出符合指定选择器的元素。
与该函数相对的是prevAll()函数,用于选取每个匹配元素之前的所有同辈元素。
next()用法示例如下:
//返回jQuery对象所有匹配元素的标识信息数组
//每个元素形如:tagName或tagName#id(如果有id的话)
functiongetTagsInfo($doms){
return$doms.map(function(){
returnthis.tagName+(this.id?"#"+this.id:"");
}).get();
}
//匹配所有span元素:e2、e3、e4、e5、e7、e9
var$span=$("span");
//匹配所有span元素之后紧邻的同辈元素:e5、e4、e8
//e2的下一个紧邻的同辈元素是e5
//e3的是e4
//e4没有(因为它是同辈元素中的最后一个,下同)
//e5没有
//e7的是e8
//e9没有
var$span_next=$span.next();
document.writeln(getTagsInfo($span_next));//SPAN#e5,SPAN#e4,A#e8
//匹配所有span元素之后紧邻的同辈span元素
var$span_next_span=$span.next("span");
document.writeln(getTagsInfo($span_next_span));//SPAN#e5,SPAN#e4
nextAll()用法示例如下:
//返回jQuery对象所有匹配元素的标识信息数组
//每个元素形如:#id
functiongetTagsInfo($doms){
return$doms.map(function(){
return"#"+this.id;
}).get();
}
var$n4=$("#n4");
//匹配n4之后所有的同辈元素
var$n4_nextAll=$n4.nextAll();
document.writeln(getTagsInfo($n4_nextAll));//#n5,#n7,#n8
//匹配n4之后的所有同辈strong元素
var$n4_nextAll_strong=$n4.nextAll("strong");
document.writeln(getTagsInfo($n4_nextAll_strong));//#n7
var$label=$("label");
var$label_nextAll_active=$label.nextAll(".active");
document.writeln(getTagsInfo($label_nextAll_active));//#n7,#n8,#n12
希望本文所述对大家的jquery程序设计有所帮助。