天天看点

jQuery高级选择器

层次选择器

<a href="https://s4.51cto.com/wyfs02/M02/A4/CD/wKioL1mx9YGjKFeLAADKI7FvwX0880.png" target="_blank"></a>

高级选择器方法:

find()、children()、next()、nextAll()、prev()、prevAll()、siblings()、nextUntil()、prevUntil()

这些方法如果不传递参数,相当于传递了('*'),即所有节点。如果传递了参数,例如

find('p'), next('a'),则表示选择指定的标签元素。

find():选择正在处理的元素的后代元素, 包括子节点、孙子节点......

find('p'):选择正在处理的元素的后代元素中的p元素

例如:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

<code>//HTML</code><code>代码</code>

<code>&lt;p&gt;p0&lt;</code><code>/p</code><code>&gt;</code>

<code>&lt;div </code><code>id</code><code>=</code><code>"box"</code><code>&gt;</code>

<code>    </code><code>&lt;p&gt;p1&lt;</code><code>/p</code><code>&gt;</code>

<code>    </code><code>&lt;p&gt;p2&lt;</code><code>/p</code><code>&gt;</code>

<code>    </code><code>&lt;div&gt;</code>

<code>        </code><code>&lt;p&gt;p3&lt;</code><code>/p</code><code>&gt;</code>

<code>    </code><code>&lt;</code><code>/div</code><code>&gt;</code>

<code>    </code><code>&lt;a href=</code><code>""</code><code>&gt;aaa&lt;</code><code>/a</code><code>&gt;</code>

<code>&lt;</code><code>/div</code><code>&gt;</code>

<code>&lt;p&gt;p&lt;</code><code>/p</code><code>&gt;</code>

<code>//JS</code>

<code>$(</code><code>'#box'</code><code>).</code><code>find</code><code>(</code><code>'p'</code><code>).css(</code><code>'color'</code><code>, </code><code>'blue'</code><code>)</code>

<code>//</code><code>被选择的元素为</code>

<code>&lt;p&gt;p1&lt;</code><code>/p</code><code>&gt;</code>

<code>&lt;p&gt;p2&lt;</code><code>/p</code><code>&gt;</code>

<code>&lt;div&gt;</code>

<code>    </code><code>&lt;p&gt;p3&lt;</code><code>/p</code><code>&gt;</code>

children(): 选择正在处理的元素的所有儿子元素,不包含孙子元素和重孙子元素

children('p'): 选择正在处理的元素的所有儿子元素中的&lt;p&gt;&lt;/p&gt;元素,不包含孙子元素中的p元素和重孙子元素中的p元素

next(): 选择正在处理的元素的同级元素的下一个元素,遇到则停止选择

next(‘p’): 选择正在处理的元素的同级元素下一个元素,如果该元素是p元素,则选择,如果没有下级元素或者下级元素第一个不是p元素,则不选择

<code>$('#box').next('p').css('color', 'red')</code>

nextAll():选择正在处理元素的同级下的所有元素,相当于nextAll(‘*’)

nextAll('p'):选择正在处理元素的同级下的所有p元素

prev()和prevAll()正好和next()、nextAll()相反,是向上选择

siblings():选择正在处理的元素的同级的所有上面的元素下面的元素,例如:

$('#box').siblings('p').css('color', 'red')

它等于

<code>$(</code><code>'#box'</code><code>).prevAll(</code><code>'p'</code><code>).css(</code><code>'color'</code><code>, </code><code>'red'</code><code>)</code>

<code>$(</code><code>'#box'</code><code>).nextAll(</code><code>'p'</code><code>).css(</code><code>'color'</code><code>, </code><code>'red'</code><code>)</code>

nextUntil(‘p’):选择正在处理元素的同级下的所有元素,直到遇到p元素后停止选择。如果同级下没有p元素,则选择所有元素。

<code>//HTML代码</code>

<code>&lt;</code><code>p</code><code>&gt;p&lt;/</code><code>p</code><code>&gt;</code>

<code>&lt;</code><code>div</code> <code>id</code><code>=</code><code>"box"</code><code>&gt;div&lt;/</code><code>div</code><code>&gt;</code>

<code>&lt;</code><code>a</code> <code>href</code><code>=</code><code>""</code><code>&gt;aaa&lt;/</code><code>a</code><code>&gt;</code>

<code>&lt;</code><code>div</code><code>&gt;div&lt;/</code><code>div</code><code>&gt;</code>

<code>&lt;</code><code>input</code> <code>type</code><code>=</code><code>""</code> <code>value</code><code>=</code><code>"提交"</code><code>&gt;</code>

<code>//JS代码</code>

<code>$(function(){</code>

<code>    </code><code>$('#box').nextUntil('p').css('color', 'red')</code>

<code>})</code>

搜索到的元素为

选择器快慢比较:

$('#box').find('p'):这条最快,使用的是原生的getElementById、ByName、ByTagName和querySelectorAll()

$('p', '#box' ):jQuery会自动把这条语句翻译成$('#box').find('p'),这会导致一定的性能损失,它比最快的形式慢了5%~10%

$('#box').children('p'):这条语句在jQuery内部,会使用$sibling()和javascript的nextSibling()方法,一个个遍历节点,他比最快的大约慢50%

$('#box &gt;p'):jQuery内部使用Sizzle引擎,处理各种选择器。Sizzle引擎的选择顺序是从右到左,所以这条语句的先选p,然后再一个个过滤出父元素#box,这导致它比最快的形式大约慢70%

$('#box p'):这条语句与上一条是同样的情况,但是,上一条只选择直接的子元素,这一条可以选择多级子元素,所以他的速度更慢,大概比最快的慢了77%

$('p', $('#box)):内部会将这条语句翻译成$('#box').find('p'),比最快的形式慢了23%

综上所述,最快的是find()方法,最慢的是$('#box p')这种高级选择器。如果一开始将$('#box')进行赋值,那么jQuery就对其变量进行缓存,那么速度回进一步提高。

<code>var</code> <code>box=$(</code><code>'#box'</code><code>)</code>

<code>var</code> <code>p = box.find(</code><code>'p'</code><code>)</code>

注意:我们应该推荐使用哪种选择器方案呢?其实,使用哪种都差不多,这里我们推荐使用jQuery提供的方法。因为不但方法的速度比高级选择器运行的更快,并且它的灵活性和扩展性要高于高级选择器。使用"+"或"~"从字面上没有next和nextAll更加语义化,更加清晰,jQuery的方法更加丰富,提供了相对的prev和prevAll。毕竟jQuery是编程语言,需要能够灵活的拆分和组合选择器,而使用CSS模式过于死板。所以,如果jQuery提供了独立的方法来替代某些选择器的功能,我们还是推荐优先选择使用独立的方法。

属性选择器

<a href="https://s2.51cto.com/wyfs02/M02/06/1E/wKiom1myAnGjo-kgAAF3TTtf1TU639.png" target="_blank"></a>

例子:

24

25

26

27

28

<code>&lt;a href=</code><code>""</code> <code>title=</code><code>"a1"</code><code>&gt;a1&lt;</code><code>/a</code><code>&gt;</code>

<code>&lt;a&gt;a2&lt;</code><code>/a</code><code>&gt;</code>

<code>&lt;a&gt;a3&lt;</code><code>/a</code><code>&gt;</code>

<code>&lt;a&gt;a4&lt;</code><code>/a</code><code>&gt;</code>

<code>&lt;a href=</code><code>""</code> <code>title=</code><code>"a5"</code><code>&gt;a5&lt;</code><code>/a</code><code>&gt;</code>

<code>//JS</code><code>代码</code>

<code>$(</code><code>'a[title]'</code><code>)    </code><code>//</code><code>选择定义了title属性的a标签元素</code>

<code>$(</code><code>'a[title=a1]'</code><code>) </code><code>//</code><code>选择title值为a1的a标签元素</code>

<code>$(</code><code>'a[title^=a]'</code><code>) </code><code>//</code><code>选择title属性值以a开头的a标签元素</code>

<code>$(</code><code>'a[title$=a]'</code><code>) </code><code>//</code><code>选择title属性值以a结尾的a标签元素</code>

<code>$(</code><code>'a[title|=a]'</code><code>) </code><code>//</code><code>选择title属性值以a开头,并且后面有一个“-”的a标签元素,例如:&lt;a href=</code><code>""</code> <code>title=</code><code>"a-1"</code><code>&gt;a1&lt;</code><code>/a</code><code>&gt;</code>

<code>$(</code><code>'a[title!=a1]'</code><code>) </code><code>//</code><code>选择有title属性,但值不等于a1的a标签元素</code>

<code>$(</code><code>'a[title~=a1]'</code><code>) </code><code>//</code><code>选择具有title属性,且属性值是以一个空格分割的列表。</code>

<code>例如: </code>

<code>&lt;a title=</code><code>"num1 aaa bbb"</code><code>&gt;aa&lt;</code><code>/a</code><code>&gt;</code>

<code>$(</code><code>'a[title~=aaa]'</code><code>)可以匹配到,$(</code><code>'a[title~=bbb]'</code><code>)也可以匹配到,$(</code><code>'a[title~=num1]'</code><code>)也可以匹配到</code>

<code>$(</code><code>'a[title*=aaa]'</code><code>) </code><code>//</code><code>类似于正则表达式,选择具有title属性,且属性值中包含aaa字符串的a标签元素</code>

<code>$(</code><code>'a[bbb][title=a1]'</code><code>) </code><code>//</code><code>多属性选择器,选择具有bbb属性,并且title属性值为a1的a元素标签</code>

本文转自 曾哥最爱 51CTO博客,原文链接:http://blog.51cto.com/zengestudy/1963490,如需转载请自行联系原作者

继续阅读