此文为作者自用复习文章
jQuery选择器:
它不仅继承了CSS选择器简洁的语法,
还继承了其获取页面便捷高效的特点,
它还拥有更加完善的处理机制;
但jQuery选择器获取元素后,为该元素添加的是行为,而CSS则是属性。
层叠选择器:
$("form input") //选择所有的form元素中的input元素 $("#main > *") //选择id值为main的所有的子元素 $("label + input") //选择所有的label元素的下一个input元素节点,经测试选择器返回的是label标签后面直接跟一个input标签的所有input标签元素 $("#prev ~ div") //同辈选择器,该选择器返回的为id为prev的标签元素的所有的属于同一个父元素的div标签
基本过滤选择器:
$(
"tr:first"
) //选择所有tr元素的第一个
$(
"tr:last"
) //选择所有tr元素的最后一个
$(
"input:not(:checked) + span"
)
//过滤掉:checked的选择器的所有的input元素
$(
"tr:even"
) //选择所有的tr元素的第0,2,4... ...个元素(注意:因为所选择的多个元素时为数组,所以序号是从0开始)
$(
"tr:odd"
) //选择所有的tr元素的第1,3,5... ...个元素
$(
"td:eq(2)"
) //选择所有的td元素中序号为2的那个td元素
$(
"td:gt(4)"
) //选择td元素中序号大于4的所有td元素
$(
"td:ll(4)"
) /选择td元素中序号小于4的所有的td元素
内容过滤选择器:
$(
"div:contains(‘John‘)"
) //选择所有div中含有John文本的元素
$(
"td:empty"
) //选择所有的为空(也不包括文本节点)的td元素的数组
$(
"div:has(p)"
) //选择所有含有p标签的div元素
$(
"td:parent"
) //选择所有的以td为父节点的元素数组
可视化过滤选择器:
$(
"div:hidden"
) //选择所有的被hidden的div元素
$(
"div:visible"
) //选择所有的可视化的div元素
属性过滤选择器:
$(
"div[id]"
) //选择所有含有id属性的div元素
$(
"input[name=‘newsletter‘]"
) //选择所有的name属性等于
‘newsletter‘
的input元素
$(
"input[name!=‘newsletter‘]"
) //选择所有的name属性不等于
‘newsletter‘
的input元素
$(
"input[name^=‘news‘]"
) //选择所有的name属性以
‘news‘
开头的input元素
$(
"input[name$=‘news‘]"
) //选择所有的name属性以
‘news‘
结尾的input元素
$(
"input[name*=‘man‘]"
) //选择所有的name属性包含
‘news‘
的input元素
$(
"input[id][name$=‘man‘]"
) //可以使用多个属性进行联合选择,该选择器是得到所有的含有id属性并且那么属性以man结尾的元素
注意:
若选择器中含有特殊符号,应用转义符转义。例:
$("#id#a") //此代码不能正确获取元素 $("#id\\#a") //正确代码
若选择器中含有空格,得到的结果也会不一致!