CSS3教程:新增加的结构伪类

2016-02-19 23:45 4 1 收藏

下面是个超简单的CSS3教程:新增加的结构伪类教程,图老师小编精心挑选推荐,大家行行好,多给几个赞吧,小编吐血跪求~

【 tulaoshi.com - Web开发 】

相关阅读文章:CSS3属性选择符介绍

4.7.3 结构伪类(Structural pseudo-classes)

CSS 3增加了大量的结构伪类,利用文档结构树来实现表现,从而可以减少页面内class属性和ID属性的定义,使得文档更加简洁。

1. E:root

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

:root { border: 1px solid blue; }

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

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)
html { border: 1px solid blue; }

2. E:nth-child(n)

匹配所有在其父元素中排第n个的E元素。n可以是数字/关键字/公式,例如:

tr:nth-child(3) {  } /* 匹配所有表格里面排第3的行tr */tr:nth-child(2n+1) {  }  /* 2n+1,公式,匹配所有奇数行 */tr:nth-child(odd) {  }   /* odd:关键字,匹配所有奇数行 */tr:nth-child(2n) {  }/* 2n:匹配所有偶数行*/tr:nth-child(even) {  }  /* even:关键字,匹配所有偶数行li */
注意:元素的第一个子元素索引为1。

利用这个伪类,可以很容易地实现双背景色甚至多背景色表格等效果。
例如有xhtml如下:

ol id="sample1"  li列表项哦列表项/li  li列表项哦列表项/li  li列表项哦列表项/li  li列表项哦列表项/li/ol

CSS如下:

#sample1 li:nth-child(even) {  /* #sample1的子元素中排序为奇数的li */background:#FF9;  /* 也可以设定float、margin、border等属性 */}#sample1 li:nth-child(odd) {background:#FC3;}

其显示如图4-41所示。

图4-41 E:nth-child(n)的应用1

也可以实现三色甚至多色的背景。例如下列代码:

#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列表项哦列表项/li  li列表项哦列表项/li  /ol

其显示如图4-42所示。

图4-42 E:nth-child(n)的应用2

此时需注意的是,3n+1表示的是3行循环内的第1行,而3n则是第3行。

同时,也可以指定某一个特定的子元素,例如下列代码:

#sample3 li:nth-child(1) {color:#F00;}#sample3 li:nth-child(2) {color:#F60;}#sample3 li:nth-child(3) {color:#FC0;}h4前3名不同显示的排行榜/h4ol id="sample3"  li列表项哦列表项/li  li列表项哦列表项/li  li列表项哦列表项/li  /ol

分别指定了第1、2、3个li的前景颜色color,其显示如图4-43所示。

图4-43 E:nth-child(n)的应用3

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

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)
#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"  trtd1-1/tdtd1-2/tdtd1-3/td  /tr  /table

其显示如图4-44所示。

图4-44 E:nth-child(n)的应用4

但是,需要特别注意的是,父元素内所有的子元素都参与排序,而无论元素的类型是什么,在上面的例子中,子元素的类型都是单一的(li或者td),而下面这个例子中,子元素的类型不再单一(包括dt和dd):

dl id="sample5"  dtdt 1,总排行1/dt  dddd 1,总排行2/dd  dtdt 2,总排行3/dt  dddd 2,总排行4/dd  dddd 3,总排行5/dd  dtdt 3,总排行6/dt  dtdt 4,总排行7/dt  dddd 4,总排行8/dd/dl

如果设定如下的CSS,那么其显示的效果则如图4-45所示。

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


图4-45 E:nth-child(n)包括父元素内所有类型的子元素

由图4-45读者可以发现,判断dt是否为奇数的条件是其在子元素内总排序,而不是dt元素单独排序。

实例演示如下:


[Ctrl+A 全部选择 提示:你可先修改部分代码,再按运行]

来源:https://www.tulaoshi.com/n/20160219/1630544.html

延伸阅读
标签: Web开发
阴影大约从CSS2就开始有了,但是只有Safari一个浏览器支持它,到现在依然是这样。阴影在CSS3中可以应用在边框和文字上,就像图片的阴影效果一样。 一般可以分为box-shadow和textshadow两类。 CSS3的box-shadow和textshadow可以写做:box-shadow:Apx Bpx Cpx #xxx; Apx = x轴 Bpx = y轴 Cpx = 投影长度 #XXX = 像通常一样的颜色 了解了这些,...
标签: Web开发
说起CSS3的新特性,就不得不提到 Media Queries 。 本文比较详细,所以很多实际中用不到。所以如果只是想简单了解Media Queries,推荐参考 CSS3 Media Queries 。 CSS2.1定义了 Media 的部分,包括类型、组别和规则等。CSS并非为了显示器而创造,而是应用于各种各样的媒体,比如常见的显示器,越来愈多的手持设备,可能略显过...
说起CSS3的新特性,就不得不提到 Media Queries 。本文比较详细,所以很多实际中用不到。所以如果只是想简单了解Media Queries,推荐参考 CSS3 Media Queries 。 CSS2.1定义了 Media 的部分,包括类型、组别和规则等。CSS并非为了显示器而创造,而是应用于各种各样的媒体,比如常见的显示器,越来愈多的手持设备,可能略显过时的电视机等等。 ...
标签: Web开发
请你注意一些CSS伪类属性不被所有浏览器支持,但有四个伪类可以安全使用在链接上 伪类像是指定选择器状态或关联选择器的门闩。它们的形式如:selector:pseudo class { property: value; },在选择器和伪属性之间使用冒号。 link 没有点击过的链接  visited以点击过的链接  active获...
标签: Web开发
你们中有许多人可能已经听到过有关CSS3的不少传言,但是我们现在能真正用到的CSS3技巧又有哪些呢?本文,我将向你展示一些 与众不同的CSS3技巧 ,这些技巧在一些主要的浏览器中表现良好(如Firefox,Chrome,Safari,Opera浏览器)。这些效果会在不支持的浏览器中降级渲染(如IE浏览器)。使用浏览器特定的声明,许多提议的CSS3样式都可以马...

经验教程

228

收藏

85
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部