Jquery获取子元素:
1.children()方法:获取该元素下的直接子集元素
2.find()方法:获取该元素下的所有子集元素
例如:
$(“ul”).children(“li”)
判断当前元素是否含有某子元素:
has()方法
例如:我判断多级菜单中,在有二级菜单的一级菜单加上下拉三角。
html结构:
<ul>
<li class="menu1">
<a>一级菜单</a>
<ul>
<li class="menu2" ><a>二级菜单</a></li>
</ul>
</li>
</ul>
代码:
$('.menu1').has('.menu2').children('a').addClass('triangle');
jQuery获取:
jQuery.parent(expr),找父亲节点,可以传入expr进行过滤,比如
(
"
s
p
a
n
"
)
.
p
a
r
e
n
t
(
)
或
者
("span").parent()或者
("span").parent()或者(“span”).parent(".class")
jQuery.parents(expr),类似于jQuery.parents(expr),但是是查找所有祖先元素,不限于父元素
jQuery.children(expr),返回所有子节点,这个方法只会返回直接的孩子节点,不会返回所有的子孙节点
jQuery.contents(),返回下面的所有内容,包括节点和文本。这个方法和children()的区别就在于,包括空白文本,也会被作为一个jQuery对象返回,children()则只会返回节点
jQuery.prev(),返回上一个兄弟节点,不是所有的兄弟节点
jQuery.prevAll(),返回所有之前的兄弟节点
jQuery.next(),返回下一个兄弟节点,不是所有的兄弟节点
jQuery.nextAll(),返回所有之后的兄弟节点
jQuery.siblings(),返回兄弟姐妹节点,不分前后
jQuery.find(expr),跟jQuery.filter(expr)完全不一样:
jQuery.filter(),是从初始的jQuery对象集合中筛选出一部分,而jQuery.find(),的返回结果,不会有初始集合中的内容,比如 ( " p " ) . f i n d ( " s p a n " ) , 是 从 < p > 元 素 开 始 找 < s p a n > , 等 同 于 ("p").find("span"),是从<p>元素开始找<span>,等同于 ("p").find("span"),是从<p>元素开始找<span>,等同于(“p span”)