麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 開發(fā) > CSS > 正文

CSS3教程:新增加的結(jié)構(gòu)偽類

2024-07-11 09:05:01
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

武林網(wǎng)(www.companysz.com)文章簡(jiǎn)介:CSS 3增加了大量的結(jié)構(gòu)偽類,利用文檔結(jié)構(gòu)樹來(lái)實(shí)現(xiàn)表現(xiàn),從而可以減少頁(yè)面內(nèi)class屬性和ID屬性的定義,使得文檔更加簡(jiǎn)潔。

相關(guān)閱讀文章:CSS3屬性選擇符介紹

4.7.3 結(jié)構(gòu)偽類(Structural pseudo-classes)

CSS 3增加了大量的結(jié)構(gòu)偽類,利用文檔結(jié)構(gòu)樹來(lái)實(shí)現(xiàn)表現(xiàn),從而可以減少頁(yè)面內(nèi)class屬性和ID屬性的定義,使得文檔更加簡(jiǎn)潔。

以下示例,請(qǐng)使用Win XP的Google Chrome或者M(jìn)AC OS X的Safari 3.1查看。

1. E:root

匹配文檔的根元素。在(X)HTML中,根元素就是<html>元素。例如:

:root { border: 1px solid blue; }

在(X)HTML文檔中,其效果等同于:

html { border: 1px solid blue; }

2. E:nth-child(n)

匹配所有在其父元素中排第n個(gè)的E元素。n可以是數(shù)字/關(guān)鍵字/公式,例如:

tr:nth-child(3) { …… }/* 匹配所有表格里面排第3的行<tr> */tr:nth-child(2n+1) { …… } /* 2n+1,公式,匹配所有奇數(shù)行 */tr:nth-child(odd) { …… } /* odd:關(guān)鍵字,匹配所有奇數(shù)行 */tr:nth-child(2n) { …… } /* 2n:匹配所有偶數(shù)行*/tr:nth-child(even) { …… } /* even:關(guān)鍵字,匹配所有偶數(shù)行l(wèi)i */

注意:元素的第一個(gè)子元素索引為“1”。

利用這個(gè)偽類,可以很容易地實(shí)現(xiàn)雙背景色甚至多背景色表格等效果。
例如有xhtml如下:

<ol id="sample1"> <li>列表項(xiàng)哦列表項(xiàng)</li> <li>列表項(xiàng)哦列表項(xiàng)</li> <li>列表項(xiàng)哦列表項(xiàng)</li> <li>列表項(xiàng)哦列表項(xiàng)</li></ol>

CSS如下:

#sample1 li:nth-child(even) { /* #sample1的子元素中排序?yàn)槠鏀?shù)的li */background:#FF9; /* 也可以設(shè)定float、margin、border等屬性 */}#sample1 li:nth-child(odd) {background:#FC3;}

其顯示如圖4-41所示。

CSS3教程:新增加的結(jié)構(gòu)偽類


圖4-41 E:nth-child(n)的應(yīng)用1

也可以實(shí)現(xiàn)三色甚至多色的背景。例如下列代碼:

#sample2 li:nth-child(3n+1) {background:#F90;}#sample2 li:nth-child(3n+2) {background:#Fc3;}#sample2 li:nth-child(3n) {background:#FF9;}<ol id="sample2"> <li>列表項(xiàng)哦列表項(xiàng)</li> <li>列表項(xiàng)哦列表項(xiàng)</li> ……</ol>

其顯示如圖4-42所示。

CSS3教程:新增加的結(jié)構(gòu)偽類


圖4-42 E:nth-child(n)的應(yīng)用2

此時(shí)需注意的是,3n+1表示的是3行循環(huán)內(nèi)的第1行,而3n則是第3行。

同時(shí),也可以指定某一個(gè)特定的子元素,例如下列代碼:

#sample3 li:nth-child(1) {color:#F00;}#sample3 li:nth-child(2) {color:#F60;}#sample3 li:nth-child(3) {color:#FC0;}<h4>前3名不同顯示的排行榜</h4><ol id="sample3"> <li>列表項(xiàng)哦列表項(xiàng)</li> <li>列表項(xiàng)哦列表項(xiàng)</li> <li>列表項(xiàng)哦列表項(xiàng)</li> ……</ol>

分別指定了第1、2、3個(gè)li的前景顏色color,其顯示如圖4-43所示。

CSS3教程:新增加的結(jié)構(gòu)偽類


圖4-43 E:nth-child(n)的應(yīng)用3

也可以為同一列的單元格td指定相同的背景色:

#sample4 td:nth-child(3n+1) {background:#FCC;}#sample4 td:nth-child(3n+2) {background:#F99;}#sample4 td:nth-child(3n+3) {background:#C6F;}<table border="0" cellspacing="0" cellpadding="0" id="sample4"> <tr><td>1-1</td><td>1-2</td><td>1-3</td> </tr> ……</table>

其顯示如圖4-44所示。

CSS3教程:新增加的結(jié)構(gòu)偽類


圖4-44 E:nth-child(n)的應(yīng)用4

但是,需要特別注意的是,父元素內(nèi)所有的子元素都參與排序,而無(wú)論元素的類型是什么,在上面的例子中,子元素的類型都是單一的(li或者td),而下面這個(gè)例子中,子元素的類型不再單一(包括dt和dd):

<dl id="sample5"> <dt>dt 1,總排行1</dt> <dd>dd 1,總排行2</dd> <dt>dt 2,總排行3</dt> <dd>dd 2,總排行4</dd> <dd>dd 3,總排行5</dd> <dt>dt 3,總排行6</dt> <dt>dt 4,總排行7</dt> <dd>dd 4,總排行8</dd></dl>

如果設(shè)定如下的CSS,那么其顯示的效果則如圖4-45所示。

#sample5 dt {font-weight:bolder;}#sample5 dt:nth-child(odd){background:#6CF;}

CSS3教程:新增加的結(jié)構(gòu)偽類


圖4-45 E:nth-child(n)包括父元素內(nèi)所有類型的子元素

由圖4-45讀者可以發(fā)現(xiàn),判斷dt是否為奇數(shù)的條件是其在子元素內(nèi)總排序,而不是dt元素單獨(dú)排序。

實(shí)例演示如下:


[Ctrl+A 全部選擇 提示:你可先修改部分代碼,再按運(yùn)行]

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 午夜视频久久久 | 失禁高潮抽搐喷水h | 黄色成人在线播放 | 久久久成人一区二区免费影院 | 欧美日韩亚洲在线观看 | 91成人天堂久久成人 | 国产精品久久久久久影院8一贰佰 | 精品久久久久久久久中文字幕 | 在线亚洲观看 | 久色乳综合思思在线视频 | 777zyz色资源站在线观看 | 国产一区二区免费 | 亚州综合图片 | 中文字幕在线永久视频 | 热99视频 | 女人叉开腿让男人桶 | av最新在线观看 | 国产精品成人一区二区三区电影毛片 | 一区在线不卡 | 国产精品爆操 | 五月天影院,久久综合, | 美女视频黄视大全视频免费网址 | 欧美视频在线一区二区三区 | 他也色在线视频 | 香蕉视频1024 | 欧美精品一区二区久久久 | 精品国产一区二区久久 | 精品国产乱码久久久久久丨区2区 | 免费日本一区二区 | 19禁国产精品福利视频 | 黄网站色成年大片免费高 | 久久亚洲一区二区三区成人国产 | 91 在线观看 | 国产亚洲精品久久久闺蜜 | 狠狠ri | 国产一精品久久99无吗一高潮 | 91性视频 | 日本在线视 | 久久久久久久九九九九 | 一区二区三区视频在线播放 | 2019中文字幕在线播放 |