3:jQuery基本筛选器
3.1:first:获取第一个元素
用法:
<ul>
<li>list item 1</li>
<li>list item 2</li>
<li>list item 3</li>
<li>list item 4</li>
<li>list item 5</li>
</ul>
jQuery代码:
$('li:first');
结果:
[ <li>list item 1</li> ]
3.2:not(selector):去除所有与给定选择器匹配的元素在jQuery 1.3中,
已经支持复杂选择器了(例如:not(div a) 和 :not(div,a))
用法:
<input name="apple" />
<input name="flower" checked="checked" />
jQuery代码:
$("input:not(:checked)")
结果:
[ <input name="apple" /> ]
3.3:even:
匹配所有索引值为偶数的元素,从 0 开始计数
用法:
<table>
<tr><td>Header 1</td></tr>
<tr><td>Value 1</td></tr>
<tr><td>Value 2</td></tr>
</table>
jQuery代码:
$("tr:even")
结果:
[ <tr><td>Header 1</td></tr>, <tr><td>Value 2</td></tr> ]
3.4:odd:
匹配所有索引值为奇数的元素,从 0 开始计数
用法:
<table>
<tr><td>Header 1</td></tr>
<tr><td>Value 1</td></tr>
<tr><td>Value 2</td></tr>
</table>
JQuery代码:
$("tr:odd")
结果:
[ <tr><td>Value 1</td></tr> ]
3.5:eq(index)
匹配一个给定索引值的元素(从0开始计数)
用法:
<table>
<tr><td>Header 1</td></tr>
<tr><td>Value 1</td></tr>
<tr><td>Value 2</td></tr>
</table>
jQuery代码:
$("tr:eq(1)")
结果:
[ <tr><td>Value 1</td></tr> ]
3.6:gt(index)
匹配所有大于给定索引值的元素(从0开始计数)
<table>
<tr><td>Header 1</td></tr>
<tr><td>Value 1</td></tr>
<tr><td>Value 2</td></tr>
</table>
jQuery代码:
$("tr:gt(0)")
结果:
[ <tr><td>Value 1</td></tr>, <tr><td>Value 2</td></tr> ]
3.7:lang(language)
选择指定语言的所有元素。:lang选择器,匹配有一个语言值等于所提供的语言代码,或以提供的语言代码开始,后面马上跟一个“ - ”的元素。
用法:
$("p:lang(it)")
3.8:last()
获取最后个元素
用法:
<ul>
<li>list item 1</li>
<li>list item 2</li>
<li>list item 3</li>
<li>list item 4</li>
<li>list item 5</li>
</ul>
jQuery代码:
$('li:last')
结果:
[ <li>list item 5</li> ]
3.9:lt(index)
匹配所有小于给定索引值的元素(从0 开始计数)
<table>
<tr><td>Header 1</td></tr>
<tr><td>Value 1</td></tr>
<tr><td>Value 2</td></tr>
</table>
jQuery代码:
$("tr:lt(2)")
结果:
[ <tr><td>Header 1</td></tr>, <tr><td>Value 1</td></tr> ]
3.10:header
匹配如 h1, h2, h3之类的标题元素
给页面内所有标题加上背景色
用法:
<h1>Header 1</h1>
<p>Contents 1</p>
<h2>Header 2</h2>
<p>Contents 2</p>
jQuery代码:
$(":header").css("background", "#EEE");
3.11:animated
匹配所有正在执行动画效果的元素
只有对不在执行动画效果的元素执行一个动画特效
用法:
<button id="run">Run</button><div></div>
jQuery:
$("#run").click(function(){
$("div:not(:animated)").animate({ left: "+=20" }, 1000);
});
3.12:focus
匹配当前获取焦点的元素。如同其他伪类选择器(那些以":“开始),建议:focus前面用标记名称或其他选择;否则,通用选择(”")是不言而喻的。换句话说,
(
′
:
f
o
c
u
s
′
)
等
同
为
(':focus')等同为
(′:focus′)等同为(’:focus’)。如果你正在寻找当前的焦点元素,$( document.activeElement )将检索,而不必搜索整个DOM树。
css代码:
.focused {
background: #abcdef;
}
html 代码:
<div id="content">
<input tabIndex="1">
<input tabIndex="2">
<select tabIndex="3">
<option>select menu</option>
</select>
<div tabIndex="4">
a div
</div>
</div>
jQuery 代码:
$( "#content" ).delegate( "*", "focus blur", function( event ) {
var elem = $( this );
setTimeout(function() {
elem.toggleClass( "focused", elem.is( ":focus" ) );
}, 0);
});
3.13:root
选择该文档的根元素。在HTML中,文档的根元素,和$(":root")选择的元素一样, 永远是元素。
设置背景颜色为黄色
$(":root").css("background-color","yellow");
3.14:target
选择由文档URI的格式化识别码表示的目标元素。如果文档的URI包含一个格式化的标识符,或hash(哈希), 然后:target选择器将匹配ID和标识符相匹配的元素。 例如,给定的URI http://example.com/#foo, $( “p:target” ),将选择
元素。这个不寻常的用法,可进一步讨论中找到 W3C CSS specification.