首頁常見問題正文

一文講透jquery基本選擇和層次選擇器【W(wǎng)eb前端知識】

更新時間:2023-01-04 來源:黑馬程序員 瀏覽量:

IT培訓(xùn)班

jQuery選擇器的出現(xiàn)不僅是為了簡化JavaScript的寫法,也是由于JavaScript提供的選擇DOM的方式較少,難以滿足實際開發(fā)的眾多需求。因此,jQuery選擇器中提供了更多選擇DOM的方式,支持從CSS1到CSS3所有的選擇器以及其他常用的選擇器。

jQuery選擇器按照功能可以分為基本選擇器、層次選擇器、過濾選擇器,下面我們詳細(xì)介紹。

一、基本選擇器

jQuery中基本選擇器是最簡單直觀的選擇器,包括id選擇器、類選擇器、元素選擇器和通配符選擇器。如下表所示:

基本選擇器
#idid選擇器,根據(jù)id值匹配一個元素單個元素
.class類選擇器,根據(jù)類名匹配元素元素集合
element元素選擇器,根據(jù)元素名匹配所有元素元素集合
*通配符選擇器,匹配所有元素元素集合
selector1,selector2,…,selectorN同時獲取多個元素元素集合
選擇器 描述 返回值

上表中,jQuery提供的同時獲取多個元素的選擇器,是利用逗號(,)分隔,將每一個選擇器匹配到的元素合并后一起返回。

為了大家更好地理解基本選擇器的使用,接下來通過一個案例進(jìn)行演示,HTML代碼片段如demo1.html所示。

<style>
	div {
		border: 1px solid black;
	}
</style>
<div id="byId">第1個div元素,id值為byDiv</div>
<p>第1個p元素</p>
<p class="byclass">第2個p元素,類名為byclass</p>
<div class="byclass">第2個div元素,類名為byClass</div>

上述代碼中,定義了兩個div元素和兩個p元素,第1個div元素的id值為byld,第2個div元素與第2個p元素設(shè)置了相同的類名byClass。

使用瀏覽器訪問demo1.html頁面的初始效果如下圖所示:

jQuery基本選擇器
圖1 頁面初始效果

下面使用不同的jQuery基本選擇器操作以上的HTML頁面。


1.id選擇器

與類選擇器不同的是,一個規(guī)范的HTML 文檔中不會出現(xiàn)多個元素具有相同id值的情況。因此,一個id選擇器只能獲取一個元素。 下面為id是byld的元素設(shè)置背景色。在demo1.html 文件中添加jQuery代碼,如下所示。

$('#byId').css('background', 'pink');

上述代碼中,css()是 jQuery提供的方法,用于設(shè)置元素的CSS樣式。其中,background用于設(shè)置背景,pink是背景顏色的值。修改完成后,重新使用瀏覽器訪問demo1.html,頁面效果如下圖所示。

jquery ID選擇器
圖2 id選擇器

2、類選擇器

一個HTML文檔中,可以為不同元素設(shè)置同名的class值,這樣便可以同時設(shè)置不同元素的相同樣式或行為。

修改demo1.html中的jQuery 代碼,為頁面中類名為byClass的所有元素設(shè)置相同的背景色。如下所示。

$('.byClass').css('background', '#a0edbc');

修改完成后,重新使用瀏覽器訪問 demo1.html,頁面效果如下圖所示。

jQuery類選擇器

圖3 類選擇器

從上圖可以看出,引用了類名為byClass的p元素和div元素都被設(shè)置了背景色。


3、元素選擇器

元素選擇器適用于開發(fā)中需要為頁面中的所有匹配元素添加樣式或行為。修改demo1.html中的jQuery代碼,將p元素中的文本大小設(shè)置為10 px,如下所示。

$('p').css('font-size', '10px');

修改完成后,重新使用瀏覽器訪問demo1.html,頁面效果如下圖所示。

jQuery元素選擇器
圖4 元素選擇器


4.通配符選擇器

在實際開發(fā)中,若需要為頁面上的所有元素添加相同的樣式或者行為,此時便可用通配符選擇器“*”一次性獲取頁面所有元素。修改demo1.html 中的jQuery代碼,將頁面的背景色設(shè)為yellow,如下所示。

$('*').css('background', 'yellow');

修改完成后,重新使用瀏覽器訪問demo1.html,頁面效果如下圖所示。

通配符選擇器

圖5 通配符選擇器

例如,修改以上的jQuery代碼,為class值為byClass和id值為byld的元素設(shè)置背景色,如下所示。

$('.byclass, #byId').css ('background', 'yellow');

通配符選擇器2
圖6 同時獲取多個元素


二、層次選擇器

層次選擇器中的“層次”是指DOM元素的層次關(guān)系。例如,按照層次結(jié)構(gòu)關(guān)系可以獲取指定DOM元素的子元素、后代元素、兄弟元素、父元素等。

jQuery的層次選擇器可以快速定位與指定元素具有層次關(guān)系的元素。層次選擇器按照DOM元素的層次可以分為子元素選擇器、后代選擇器和兄弟選擇器,具體如下表所示。


層次選擇器
parent>child子元素選擇器,根據(jù)父元素匹配所有的子元素元素集合
selector selector1后代選擇器, 根據(jù)祖先元素(selector)匹配所有的后代元素(selector1)元素集合
prev + next兄弟選擇器,匹配prev元素近鄰的兄弟元素元素集合
prev ~ siblings兄弟選擇器,匹配prev元素后代的所有兄弟元素元素集合
選擇器 描述 返回值

為了大家更好地理解層次選擇器的使用,接下來通過一個案例為讀者進(jìn)行演示,HTML代碼片段如 demo2.html所示。

<p>這是div前面的p元素</p>
<div id="dv">
	<p>這是div中的第1個p元素</p>
	<ul>
		<li>這是第1個li元素</li>
		<li><p>這是第2個li中的p元素</p></li>
	</ul>
	<p>這是div中的第2個p元素</p>
</div>
<p>這是div后面的第1個p元素</p>
<p>這是div后面的第2個p元素</p>
<p>這是div后面的第3個p元素</p>

頁面結(jié)構(gòu)設(shè)計完成后,下面將最外層的div元素當(dāng)做默認(rèn)的元素,子元素、后代元素以及兄弟元素都是相對于該div元素進(jìn)行操作。使用瀏覽器訪問demo2.html,頁面的初始效果如下圖所示。

層次選擇器
圖7 頁面初始效果

下面使用不同的jQuery基本選擇器操作以上的HTML頁面。

1. 子元素選擇器

子元素選擇器指的是通過父元素(parent)獲取其下的指定子元素(child)。下面在demo2.html文件中添加如下jQuery 代碼,為div元素的子元素添加背景色。

 $('#dv >p').css('backgroundColor', 'red');

上述代碼中,在選擇器中通過符號“>”獲取id值為dv下的所有子元素p,并修改它們的背景色。修改完成后,使用瀏覽器訪問 demo2.html,頁面效果如下圖所示。

子元素選擇器
圖8 子元素選擇器

從上圖可以看出,程序僅為id值為dv的元素下的p元素添加背景色,不會影響其他p元素的樣式。

多學(xué)一招:children()方法

在jQuery中,還可以使用children()方法代替子元素選擇器,獲取指定元素的子元素.例如,獲取demo2.html中,id值等于dv的元素下所有的子元素p,如下所示。

$('#dv >p');                //使用子元素選擇器獲取
$('#dv').children('p');     //使用 children()方法獲取

上述代碼中,children()方法的參數(shù)p表示要獲取的子元素,調(diào)用該方法的是子元素的父元素對象,如$('div')。


2. 后代選擇器

后代元素與子元素的區(qū)別在于,后代元素不僅包括子元素,還包括子元素下的所有其他元素。

替換demo2.html中的jQuery 代碼,為id值等于dv的所有后代p元素添加背景色,如下所示。

$('#dv p').css('backgroundColor', 'red');

上述代碼中,在選擇器中通過空格,獲取id值為dv下的所有后代p元素,并修改它們的背景色。修改完成后,使用瀏覽器訪問 demo2.html,頁面效果如下圖所示。

后代選擇器
圖9 后代選擇器

對比圖9與圖8,可以清楚地看出jQuery的子選擇器和后代選擇器的區(qū)別。

多學(xué)一招:find()方法

在jQuery中,還可以使用find()方法獲取指定元素的后代元素。例如,獲取 demo2-2.html 中 id值等于dv的元素下所有后代p元素,如下所示。

$('#dv p');					//使用后代選擇器荻取
$('#dv') .find ('p');		//使用find()方法獲取

上述代碼中,find()方法傳遞的參數(shù)p表示要獲取的所有后代p元素。

3. 兄弟選擇器

通過兄弟選擇器可以獲取指定元素的兄弟元素,兄弟元素可以理解為同輩元素或同級元素。

修改demo2.html中的jQuery代碼,為id為dv下一個p元素設(shè)置背景色,如下所示。

$('#dv + p').css('backgroundColor', 'red');

上述代碼中,在選擇器中通過符號“+”獲取緊鄰id值為dv的下一個兄弟元素p,并修改它的背景色。修改完成后,使用瀏覽器訪問demo2.html,頁面效果如下圖所示。

獲取相鄰兄弟元素
圖10 獲取相鄰兄弟元素

另外,若要獲取指定元素后的所有兄弟元素,可以在選擇器中使用符號“~”。修改demo2.html 頁面中的jQuery代碼,如下所示。

$('#dv ~ p').css('backgroundColor', 'red');

修改完成后,使用瀏覽器訪問demo2.html,頁面效果如圖11所示。

獲取所有兄弟元素

對比圖11與圖10可以清楚地看出,“prev + next”僅能獲取prev元素緊鄰的下一個同級元素,“prev ~ siblings”可獲取prev后的所有同級元素。

多學(xué)一招:next()、nextAll()和siblings()方法的使用

jQuery中提供的next()方法可獲取指定元素緊鄰的下一個兄弟元素,nextAll()方法可獲取指定元素后的所有兄弟元素,而siblings()方法則可獲取指定元素的所有兄弟元素。

下面以demo2.html為例進(jìn)行演示,示例代碼如下。

    //獲取id為dv后緊鄰的兄弟元素p
    $('div').next('p').css('background', 'red');
    //獲取id為dv后所有兄弟元素p
    $('div').nextAll('p').css('background', 'red');
    //獲取id為dv的所有兄弟元素p
    $('div').siblings('p').css('background', 'red');

siblings()獲取所有兄弟元素
圖12 siblings()獲取所有兄弟元素

上述代碼中,前兩行代碼獲取的p元素分別與圖10和圖11相同。最后一行獲取的p元素頁面效果如圖12所示。

分享到:
在線咨詢 我要報名
和我們在線交談!