快上网专注成都网站设计 成都网站制作 成都网站建设
成都网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

jquery子类,浅谈jquery的应用

jquery实现子类全选中,则父类自动选中

先MARK一个,等会上代码。。

崇阳网站制作公司哪家好,找成都创新互联公司!从网页设计、网站建设、微信开发、APP开发、成都响应式网站建设等网站项目制作,到程序开发,运营维护。成都创新互联公司于2013年成立到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选成都创新互联公司

运行效果:

完整HTML代码:

!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" ""

html xmlns=;

head

meta http-equiv="Content-Type" content="text/html; charset=gbk"/

titleDocument/title

script src=""/script

script type="text/javascript" 

//全部选择

$(function(){

$("ul.categories input").click(function(){

var children = $(this).next();

var isChecked = $(this).prop("checked");

if(children){

if(isChecked){

children.find("input").prop("checked","checked");

}else{

children.find("input").removeProp("checked");

}

}

//同级分类当前选中的个数

var checkedCount = $(this).parent().parent().find("li input:checked").length;

//同级分类当总的个数

var count = $(this).parent().parent().find("li input").length;

if(checkedCount == count){

$(this).parent().parent().parent().find("input").prop("checked","checked");

}else{

$(this).parent().parent().parent().find("input").removeProp("checked");

}

});

});

/script

/head

body

ul class="categories"

liinput type="checkbox" id="lvl2"/数码电子

ul

liinput type="checkbox" id="lvl3"/手机/li

liinput type="checkbox" id="lvl3"/电脑/li

liinput type="checkbox" id="lvl3"/U盘/li

liinput type="checkbox" id="lvl3"/相机/li

/ul

/li

liinput type="checkbox" id="lvl2"/服装

ul

liinput type="checkbox" id="lvl3"/毛衣/li

liinput type="checkbox" id="lvl3"/T恤/li

liinput type="checkbox" id="lvl3"/羽绒服/li

liinput type="checkbox" id="lvl3"/秋裤/li

/ul

/li

liinput type="checkbox" id="lvl2"/饰品

ul

liinput type="checkbox" id="lvl3"/纯金/li

liinput type="checkbox" id="lvl3"/纯银/li

/ul

/li

liinput type="checkbox" id="lvl2"/家电

ul

liinput type="checkbox" id="lvl3"/电饭煲/li

liinput type="checkbox" id="lvl3"/电磁炉/li

liinput type="checkbox" id="lvl3"/吸尘器/li

liinput type="checkbox" id="lvl3"/液化气灶/li

/ul

/li

/ul

/body

/html

在Jquery里,怎样得到其父下对应的子类?代码如下

$(function(){

$(".listCont1").click(function(event){

//由于冒泡事件,要先判断是哪个响应的click

if($(this).attr('class').indexOf('clear')-1)//触发的是父div

{

$(this).find('input').prop("checked");

return false;//结束冒泡

}

else if($(this).is('input'))//触发的是input

{

$(this).prop("checked");

return false;//结束冒泡

}

else    //触发的是子控件

{

$(this).parent().find('input').prop("checked");

return false;//结束冒泡

}

});

});

注意,prop需要JQuery1.6以上版本。

jquery选择器 如果选中多个名字一样的DIV里面的同名子类

不知道你说的选中是如何操作的,给你个例子。

var obj=$(this);//比如说这是你获取选中的div class="a1"的对象。

获得a1对象下边的第一个div class="a2", $(obj).children(":first")

jquery 如何遍历子类?

$(".n").children().echo(function(){

if($(this).attr("class")=="a2") $(this).attr("class","a9");

})

只是不懂为何一定要遍历找出a2 ,为何不直接更改。例如:

$(".n.a2").attr("class","a9");

jquery如何获取第一个或最后一个子元素?

通过children

children("input:first-child")

$(this).children("input:first-child").val();

$(this).children("input:last-child").val();

通过选择器,$(".itemsinput:first")

1. 通过位置选择的操作:

:first:默认情况下是相对整个页面来说的第一个,如:li:first表示整个页面的第一个li元素,而ul li:first表示整个页面的第一个li元素,并且是在ul下的子元素;

:first- child:为每个父元素匹配第一个子元素,如li:first-child返回每个ul的第一个li元素。可以这样理解,页面中的元素有相同的父元素 的,并且里面又包含li元素的,那么就取第一个li元素,每个子类集合都要进行判断,直到找出所有符合要求的li元素;

:only- child:返回所有没有兄弟节点的元素,注意,文本元素不是,也就是说类似这样的divhelloa href=""jquery/a/div,对于这段会选出a元素;对 于$(”label:only-child“)会选出是label元素,同时它是它父类唯一的子元素的label元素;

:nth-child(n):返回第n个子节点,n从1开始,如果n取0,那么就会选择所有的元素。如:[*]li:nth-child(2)返回li元素,并且该元素是其父元素的第二个子元素;

:nth-child(even|odd):返回偶数或奇数的子节点;

:nth-child(An+B):返回满足表达式An+B的所有子节点,比如3n+1返回所处位置为父节点子元素的是3的倍数加1的那个子元素;

:even:页面范围内的处于偶数位置的元素,如:li:even返回全部偶数li元素;

:odd:页面范围内的处于奇数位置的元素;

:eq(n):第n个匹配的元素(n从0开始),如:li:eq(3)返回整个页面的第四个li元素,ul li:eq(1)返回页面中第一个ul元素下的第二个li元素,注意:只匹配一次就返回了;

:gt(n):第n个匹配元素(不包括)之后的元素(n从0开始),如:ul:gt(2)返回从第3个ul开始的所有ul元素(含第三个);

:lt(n):第n个匹配元素(不包括)之前的元素(n从0开始),如:ul:lt(2)返回从第0个和第1个ul元素;

2. 利用css选择器进行选择:

元素标签名:比如说$(”a“)会选出所有链接元素;

#id:通过元素id进行选择,比如说$("#form1")会选择id为form1的元素;

.class:通过元素的CSS类来选择,比如说$(".boldstyle")会选择CSS为boldstyle类的元素;

标签 名#id.class:通过某类元素的id属性和class属性来选择,如:$(a#blog.boldStyle)会选择id为blog并且CSS类型 为.boldStyle类型的链接元素(a id='blog' class='.boldStyle');

父标签名 子标签名.class:通过选择父标签下的某种CSS类型的子元素,如:$(p a.redStyle)会选择p段落元素中的链接子元素a,且其css类型为.redStyle;

3. 通过子选择器,容器选择器和属性选择器进行选择:

*:匹配所有的元素,比如说:$(*)会把页面中的所有元素都返回;

E:匹配标签名为E的所有元素,如$("a")返回所有链接元素;

E F:匹配父元素E下的标签名为F的所有子元素(F可以为E的子类的子类,甚至更远);

EF:匹配父元素E下的所有标签名为F的直接子元素;

E+F:匹配所有标签名为F的元素,并且有E类型的兄弟节点在该F元素之前(E,F紧挨着);

E~F:匹配前面是任何兄弟节点E的所有元素F(E,F不必紧挨着);

E:has(F):匹配标签名为E,至少有一个标签名为F的后代节点的所有元素E;

E.C:匹配带有类名C的所有元素E。.C等效于*.C;

E#I:匹配id为I的所有元素E,#I等效于*#I;

E[A]:匹配带有属性A的所有元素E;

E[A=V]:匹配所有属性A的值为V的元素E;

E[A^=V]:匹配所有元素E,且A的属性值是V开头的;

E[A$=V]:匹配所有元素E,且A的属性值是V结尾的;

E[A*=V]:匹配所有元素E,且A的属性值中包含有V;

4.利用jQuery自定义的选择器进行选择:

:button:选择任何按钮类型的元素,包括input[type=submit]等等;

:checkbox:选择复选框元素;

:file:选择所有文件类型元素,即input[type=file];

:image:选择表单中的图像元素,即input[type=image],注意此处和前面根据标签名img选择图像有点不同哈;

:input:选择表单元素,如input,select,textarea,button等;

:radio:选择单选按钮元素;

:reset:选择复位按钮元素,如input[type=reset],button[type=reset];

:submit:选择提交按钮元素;

:text:选择文本字段元素,即input[type=text];

:animated:选择当前处于动态控制下的元素;

:contains(hello):选择包含文本hello的元素;

:header:选择标题元素,如h1;

:parent:选择拥有后代节点(包括文本)的元素,而排除空元素;

:selected:选择已选中的选项元素;

:visible:选择可见元素;


本文题目:jquery子类,浅谈jquery的应用
网页网址:http://6mz.cn/article/dssphoj.html

其他资讯