CSS 选择器
- 1. 1. 选择器语法
- 2. 2. 选择器组
- 3. 3. 简单选择器
- 3.1. 3.1 类型选择器
- 3.2. 3.2 通用选择器
- 3.3. 3.3 属性选择器
- 3.4. 3.4 类选择器
- 3.5. 3.5 ID选择器
- 3.6. 3.6 伪类
- 3.6.1. 3.6.1 动态伪类
- 3.6.2. 3.6.2 目标伪类:target
- 3.6.3. 3.6.3 语言伪类:lang
- 3.6.4. 3.6.4 UI元素状态伪类
- 3.6.5. 3.6.5 结构伪类
- 3.6.5.1. 3.6.5.1 :root伪类
- 3.6.5.2. 3.6.5.2 :nth-child()伪类
- 3.6.5.3. 3.6.5.3 :nth-last-child()伪类
- 3.6.5.4. 3.6.5.4 :nth-of-type()伪类
- 3.6.5.5. 3.6.5.5 :nth-last-of-type()伪类
- 3.6.5.6. 3.6.5.6 :first-child伪类
- 3.6.5.7. 3.6.5.7 :last-child伪类
- 3.6.5.8. 3.6.5.8 :first-of-type伪类
- 3.6.5.9. 3.6.5.9 :last-of-type伪类
- 3.6.5.10. 3.6.5.10 :only-child伪类
- 3.6.5.11. 3.6.5.11 :only-of-type伪类
- 3.6.5.12. 3.6.5.12 :empty伪类
- 3.6.6. 3.6.6 空白
- 3.6.7. 3.6.7 否定伪类
- 4. 4. 伪元素
本文是从Selectors Level 3提取出的一些重点,如有不懂的地方可以看原文对照。
1. 选择器语法
一个选择器是一个或多个被连结符分隔的简单选择器序列组成的链。一个伪元素可能会附加到选择器中的最后一个简单选择器序列。
一个简单选择器序列是没有被连结符分隔的简单选择器组成的链。它总是以一个类型选择器或通用选择器开始。除了类型选择器和通用选择器,没有其他类型的选择器允许在序列中。
一个简单选择器可以是类型选择器,通用选择器,属性选择器,类选择器,id选择器或伪类。
连结符可以是:空白、>
、+
、~
。
一个文档树的元素被选择器所代表,它是选择器的主题(subject)。一个选择器组成了一个简单选择器的单一序列,代表了任何满足它需求的元素。前面加上其他的简单选择器序列,且序列中的连结符施加了额外的匹配限制,所以一个选择器的主题总是最后一个简单选择器序列所代表的元素的子集。
一个空的选择器,没有包含简单选择器序列和伪元素,是一个无效的选择器。
选择器中的字符可以根据在CSS2
中相同的转义规则并通过\
来转义。
2. 选择器组
一个逗号分隔的选择器列表表示了被任何单一选择器选择的所有元素的组合。例如,在CSS
中当一些选择器共享相同的声明时,它们可以组合成一个逗号分隔的列表。空格可能出现在逗号的前面或后面。
CSS
实例:
1 | h1 { font-family: sans-serif } |
上面等价于:
1 | h1, h2, h3 { font-family: sans-serif } |
注意:在本例中等价是真的,因为所有的选择器是有效的选择器。如果选择器中的一个是无效的选择器,那么整个声明是无效的。
无效的CSS
实例:
1 | h1 { font-family: sans-serif } |
不等价于:
1 | h1, h2..foo, h3 { font-family: sans-serif } |
在实际应用中也没有人这样写了。否则肯定早晚开除了。
3. 简单选择器
3.1 类型选择器
一个类型选择器是文档语言元素类型的名称,并使用CSS qualified names语法。一个类型选择器表示了在文档树中元素类型的实例。
实例:
以下的选择器表示了在文档树中的h1
元素:
1 | h1 |
3.1.1 类型选择器和命名空间
类型选择器允许一个可选的命名空间组件:一个命名空间前缀被定义在元素名的前面,并通过|
符号来分隔。
命名空间可能为空,代表了选择器没有命名空间。
一个*
可被用作为命名空间前缀,表明代表了元素的所有命名空间。
元素类型选择器在没有命名空间组件时代表了元素不会考虑元素的命名空间(等价于*|
),除非定义了一个默认的命名空间。如果一个默认命名空间被声明,这些元素会代表在默认命名空间中的元素。
那怎么定义默认命名空间呢?
1 | @namespace "http://www.w3.org/1999/xhtml"; |
上面的http://www.w3.org/1999/xhtml
就为默认的命名空间。
总结(要注意的是|
前后没有空格的哟):
ns|E
元素为E
且在命名空间ns
中
*|E
元素为E
且在任何命名空间中
|E
元素为E
且没有命名空间
E
如果没有为选择器定义默认的命名空间,这个等价于*|E
。否则等价于ns|E
,且ns
为默认的命名空间。
CSS
实例:
1 | @namespace foo url(http://www.example.com); |
第一条规则只会匹配在http://www.example.com
命名空间中的h1
元素。
第二条规则会匹配在http://www.example.com
命名空间中的所有元素。
第三条规则只会匹配没有命名空间的h1
元素。
第四条规则会匹配在任何命名空间中的h1
元素。
第五条规则等价于第四条规则,因为没有默认的命名空间被定义。
3.2 通用选择器
通用选择器,用*
来表示,它代表了任何元素类型的限定名。它代表了在文档树中的任何命名空间的任何单一元素,如果没有为选择器指定默认的命名空间。如果指定了默认的命名空间,可以看下面的通用选择器和命名空间。
如果一个通用选择器不是选择器序列的唯一组件,或者它后面紧跟了伪元素,那么*
可以省略,通用选择器隐含的表示存在。
实例:
*[hreflang|=en]
和[hreflang|=en]
是等价的*.warning
和.warning
是等价的*#myid
和#myid
是等价的
3.2.1 通用选择器和命名空间
通用选择器允许一个可选的命名空间组件。它可以按照以下方式来使用:
ns|*
在ns
命名空间中的所有元素
*|*
所有元素
|*
所有没有命名空间的元素
*
如果没有默认指定默认的命名空间,则等价于*|*
,否则等价于ns|*
,如果ns
为默认的命名空间。
3.3 属性选择器
选择器允许表示元素的属性。当选择器被用作为一个表达式来匹配元素时,属性选择器必须认为匹配元素如果元素有一个属性且匹配属性选择器所代表的属性时。
3.3.1 属性存在和值选择器
CSS2
介绍了四种属性选择器:
[att]
代表了元素有一个att
属性,不管属性的值是什么。
[att=val]
代表了元素有一个att
属性,且值为val
。这种可以用于选择例如:input[type="text"]
[att~=val]
代表了元素有一个att
属性,且它的值为空白分隔的列表,其中的一个值为val
,如果选择器中的val
包含了空白,它永远不会代表什么。同样,如果val
为空字符串,它永远不会代表什么。
[att|=val]
代表了元素有一个att
属性,且它的值为val
或者val
紧跟着-
。
实例:
下面的属性选择器代表了h1
元素,且它有一个title
属性,且不管值为多少:
1 | h1[title] |
下面的例子选择器代表了一个span
元素它的class
属性的值为example
:
1 | span[class="example"] |
下面的选择器代表了一个a
元素,且它的hreflang
属性值为en
或en-US
等
1 | a[hreflang|="en"] |
3.3.2 子字符串匹配属性选择器
三个附加的属性选择器被提供给匹配属性值的子字符串:
[att^=val]
代表了元素有一个att
属性,且值以val
前缀开始。如果val
为空字符串,则这个选择器不会代表任何元素
[att$=val]
代表了元素有一个att
属性,且值以val
后缀结束。如果val
为空字符串,则这个选择器不会代表任何元素
[att*=val]
代表了元素有一个att
属性,且值包含至少子字符串val
的一个实例。如果val
为空字符串,则这个选择器不会代表任何元素
实例:
下面的选择器代表了一个HTML
的object
,引用了一个图片:
1 | object[type^="image/"] |
下面的选择器代表了一个HTML
链接a
,且它的href
属性以.html
结尾:
1 | a[href$=".html"] |
下面的选择器代表了HTML
段落中title
属性包含了子字符串hello
:1
p[title*="hello"]
3.3.3 属性选择器和命名空间
在属性选择器中的属性名是以CSS限定名给出:先前已声明的命名空间前缀可预先准备给由命名空间分隔符|
分隔的属性名。为了保持命名空间在XML
中的推荐,默认的命名空间不会应用到属性中,因此,没有命名空间组件的属性选择器只应用到那些没有命名空间的属性。一个*
可能被用于命名空间前缀以表明该选择器可匹配所有属性名而不用考虑属性的命名空间。
一个属性选择器有一个属性名包含了命名空间前缀,但是该命名空间没有在之前定义,这时该属性选择器是一个无效的选择器。
CSS
实例:
1 | @namespace foo "http://www.example.com"; |
第一条规则只匹配有在http://www.example.com
命名空间下的属性att
,且值为val
的元素。
第二条规则只匹配具有属性att
,且不管属性的命名空间。
最后两条规则是等价的,且只匹配具有属性att
,且该属性不在任何命名空间下的元素。
3.3.4 在DTDs
中的默认属性值
属性选择器代表了在文档树中的属性值。文档树如何构建是在选择器之外的。在某些文档格式中,默认的属性值可以定义在DTD
或其他地方,如果它们出现在文档树中的话,这些只能通过属性选择器来选择。选择器的设计应该使它们工作,不管默认值是否包含在文档树中。
例如,一个XML
的用户代理可能并不需要去读取一个DTD
的外部子集
,但是需要在文档的内部子集
寻找默认属性值(看这里:XML10)。取决于用户代理,一个定义在DTD
的外部子集的默认的属性值可能会或可能不会出现在文档树中。
一个识别XML
命名空间的用户代理可能不需要利用它的对于那个命名空间的认知来对待默认的属性值,就好像它们就在文档中。(例如,一个XHTML
的用户代理不需要利用它内置的该XHTML DTD
的认知)
实例:
考虑一个元素example
,它有一个属性radix
,且其默认值为decimal
。DTD
片段可能为:
1 | <!ATTLIST EXAMPLE radix (decimal,octal) "decimal"> |
如果样式表包含了这些规则:
1 | EXAMPLE[radix=decimal] { /*... default property settings ...*/ } |
第一条规则可能不会匹配那些radix
属性被设置为默认值的元素,即为明确设置。为了捕获所有情况,属性选择器的默认值必须被舍弃:
1 | EXAMPLE { /*... default property settings ...*/ } |
3.4 类选择器
与HTML
工作,作者可能会使用句点
符号(也就是.
)来代替~=
符号表示class
属性。因此,对于HTML
,div.value
和div[class~=value]
是具有同样的含义的。该属性值必须紧跟在.
符号后面。
如果用户代理具有命名空间特定的知识,且允许它确定哪个属性是class
属性用于各个命名空间,用户代理可能使用.
符号在XML
文档中应用选择器。
CSS实例:
我们可以通过以下方式来分配样式给所有class~="pastoral"
的元素:
1 | *.pastoral { color: green } /* all elements with class~=pastoral */ |
或者只是:
1 | .pastoral { color: green } /* all elements with class~=pastoral */ |
以下只分配样式给所有class~="pastoral"
的h1
元素:
1 | H1.pastoral { color: green } /* H1 elements with class~=pastoral */ |
3.5 ID选择器
文档语言可以包含声明为ID类型的属性。ID类型属性的特殊之处在于在一致性的文档中没有两个这样的属性可以有相同的值,且不管携带该属性的元素类型;无论什么文档语言,一个ID类型属性可被用于唯一地标识其元素。
ID选择器是以#
开头,然后紧跟着ID值。
实例:
以下ID选择器代表了一个h1
元素,且它的id属性值为chapter1
1 | h1#chapter1 |
不过很少会像上面这样写,一般是像下面这样:
1 | #chapter1 |
3.6 伪类
伪类的概念被引入以允许选择位于该文档树以外或者使用其他简单选择器不能表达的信息。
一个伪类总是包含:
跟着伪类的名称和一个可选的值被放在圆括号之间。
伪类中允许包含在选择器中的所有简单选择器序列。伪类可以出现在简单选择器序列的任何地方,类型选择器和通用选择器(可能省略)后面。伪类名是不区分大小写。一些伪类是相互排斥的,而另一些可以同时施加到相同的元素。伪类可能是动态的,在这个意义上,元素可能获得或失去一个伪类当用户与文档进行交互的时候。
3.6.1 动态伪类
动态伪类在特性上分类元素,除了它们的名字、属性或内容,原则上特性不能从文档树中推断出来。
动态伪类不会出现在文档源或文档树中。
3.6.1.1 链接伪类::link
和:visited
用户代理通常显示未访问的链接不同于之前访问过的。选择器提供了伪类:link
和:visited
来区分它们。
:link
伪类应用在那些没有被访问过的链接:visited
伪类应用在那些已经被用户访问过的链接
经过一定的时间,用户代理可能选择返回一个访问过的链接为:link
状态。
这两种状态是互斥的。
实例:
下面的选择器代表了有一个external
类的链接,且被访问过:
1 | a.external:visited |
用户代理可能会因此对待所有的链接为未访问链接,或者采取其他措施以保护用户的隐私,而对访问和未访问链接渲染出不同。
3.6.1.2 用户动作伪类:hover
、:active
和:focus
交互式用户代理有时会为了响应用户操作而改变呈现。选择器提供了三个伪类来选择这些用户正在作用的元素。
:hover
伪类应用在当用户通过定位设备来指定元素,但不一定激活它时。例如,一个视觉用户代理可以应用伪类当光标悬停到元素所生成的盒子上时。用户代理不支持交互式媒体的不需要支持该伪类。支持交互式媒体的一些用户代理可能无法支持这个伪类。:active
伪类应用在正被用户激活的元素上。例如,在用户按下鼠标按钮和释放它之间。在多于一个鼠标按钮的系统,:active
仅应用在主激活按钮(通常是鼠标左键),以及它们的任意别名。:focus
伪类应用在获得焦点的元素
这些伪类不是相互排斥的。一个元素可以在相同的时间匹配的几个伪类。
选择器没有定义当元素的父亲也在:active
或:hover
状态时。
实例:
1 | a:link /* unvisited links */ |
或者结合多个动态伪类:
1 | a:focus |
3.6.2 目标伪类:target
一些URIs
会引用资源内的一个位置。这种类型的URI
是以#
紧跟锚标识符结束。
有片段标识浮的URIs
链接到文档内的某个元素,被称为目标元素。举例来说,这里给出了一个URI
指向文档中一个名为section_2
的锚。
1 | http://example.com/html/top.html#section_2 |
一个目标元素可以使用:target
伪类来表示。如果文档的URI没有片段标识符,则该文档没有目标元素。
实例:
1 | p.note:target |
这个选择器代表了一个p
标签,且它有一个类note
,且它是指定URI
的目标元素时。
3.6.3 语言伪类:lang
如果文档语言指定了一个元素的人类语言如何确定,则可以使用选择器来代表基于该语言的元素。例如,在HTML
中,语言是由lang
属性和从meta
元素的信息或HTTP
协议联合决定的。XML
使用一个叫做xml:lang
的属性,并且还可能有其他的文档语言特定的方法,用于确定使用的语言。
伪类:lang(C)
代表了在语言C
中的元素。一个元素是否通过:lang
被代表是完全基于元素的语言值是否和标识符C
相等,或者是以标识符C
开始并紧跟着-
。对C
和元素语言值的匹配是不区分大小写的。标识符C
不必须是一个有效的语言名称。
C
必须是一个有效的CSS
标识符,且不能为空。
实例:
1 | html:lang(fr-be) |
3.6.4 UI元素状态伪类
3.6.4.1 :enabled
和:disabled
伪类
:enabled
伪类代表了处于激活状态的用户界面元素;这些元素都有相应的禁用状态。
相反地,:disabled
伪类代表了处于禁用状态的用户界面元素;这些元素都有相应的激活状态。
什么构成激活状态、禁用状态和用户界面元素是语言决定的。在一个典型的文档中大多数元素即不会是:enabled
也不会是:disabled
。
那什么元素有这种状态呢,input
、textarea
等元素。
1 | <style> |
3.6.4.2 :checked
伪类
单选框和复选框元素可以被用户切换。一些菜单项被勾选,当用户选择它们的时候。:checked
伪类就是应用在这些有selected
和checked
属性的元素,这些元素包含checkbox
、radio
、option
等。
实例:
1 | <style> |
3.6.4.3 :indeterminate
伪类
这个是对于radio
和checkbox
有时处于一种模糊的状态,即不是checked
,也不是unchecked
。
3.6.5 结构伪类
选择器引入了结构伪类的概念,允许基于在文档树中确定的信息来选择,但是不能通过其他简单选择器或连结符来表示。
当在它父亲的孩子列表中计算一个元素的位置时,独立文本和其他非元素节点不计算在内当计算在其父亲的孩子列表中的元素的位置,该指数的编号从1开始。
3.6.5.1 :root
伪类
:root
伪类代表了文档的根元素。在HTML4
中总是html
元素。
3.6.5.2 :nth-child()
伪类
:nth-child(an+b)
伪类可以代表在文档树中在它之前的有an+b-1
个兄弟的元素,n
可以为任何的正数或0,且有一个父元素。对于大于0的a
和b
,这有效的将元素的孩子分成每组a
个元素,然后选择每组中的第b
个元素。例如,这使得选择器解决table
中每隔一行的问题,并可以用于段落文本中每四个交替颜色。a
和b
的值必须为整数。元素的子元素的索引是从1
开始(要注意不是JavaScript
等语言的0哟)。
除此之外,:nth-child()
还可以接受odd
和even
作为参数。odd
其实等价于2n+1
,even
其实等价于2n
。
:nth-child()
的参数必须匹配以下语法规则,INTEGER
匹配[0-9]+
,标记的其余部分是由Lexical scanner给出。
1 | nth |
实例:
1 | tr:nth-child(2n+1) /* represents every odd row of an HTML table */ |
当b
的值前面有一个负号,则+
字符必须从表达式中移除。
实例:
1 | :nth-child(10n-1) /* represents the 9th, 19th, 29th, etc, element */ |
当a=0
,则an
部分可以不包含。当an
未包含且b
为非负数,则在b
前面的+
字符也可省略。
实例:
1 | foo:nth-child(0n+5) /* represents an element foo that is the 5th child |
当a=1
或a=-1
,数字可以从规则中省略。
实例:
1 | bar:nth-child(1n+0) /* represents all bar elements, specificity (0,1,1) */ |
当b=0
,则每一个第a
个元素被选择。在这种情况,+b
或-b
部分可能省略,除非a
部分已经被省略。
实例:
1 | tr:nth-child(2n+0) /* represents every even row of an HTML table */ |
空白是允许出现在(之后
或)
之前,也可以出现在+
或-
任何一方以分割an
和b
部分,当它们都没有省略的时候。
有效的实例:
1 | :nth-child( 3n + 1 ) |
下面是无效的:
1 | :nth-child(3 n) |
当a
和b
都为0时,该伪类没有选择文档树中的任何元素。
a
的值可能为负数,但是只有在an+b
的正数位置才可以被选择。
实例:
1 | html|tr:nth-child(-n+6) /* represents the 6 first rows of XHTML tables */ |
3.6.5.3 :nth-last-child()
伪类
其实这个伪类和前面的:nth-child()
是很类似的,它只是从最后一个元素开始计算索引。:nth-last-child(an+b)
伪类可以代表在文档树中在它之后
的有an+b-1
个兄弟的元素,n
可以为任何的正数或0,且有一个父元素。这个可以参考上面的:nth-child()
语法。它同样接受odd
和even
作为参数。
实例:
1 | tr:nth-last-child(-n+2) /* represents the two last rows of an HTML table */ |
3.6.5.4 :nth-of-type()
伪类
这个伪类其实可以看成对:nth-child()
施加了一个限制,那就是元素类型必须相同。:nth-of-type(an+b)
伪类可以代表在文档树中在它之前有an+b-1
个兄弟,且元素类型必须相同
的元素,n
可以为任何的正数或0,且有一个父元素。这个可以参考上面的:nth-child()
语法。它同样接受odd
和even
作为参数。
实例:
1 | img:nth-of-type(2n+1) { float: right; } |
再看一个例子:
1 | <style> |
你可以在浏览器中对比以下这两个选择器的效果哟。
3.6.5.5 :nth-last-of-type()
伪类
这个伪类和:nth-of-type()
,只是从最后一个元素开始计算索引啦。:nth-last-of-type(an+b)
伪类可以代表在文档树中在它之后
有an+b-1
个兄弟,且元素类型必须相同
的元素,n
可以为任何的正数或0,且有一个父元素。这个可以参考上面的:nth-child()
语法。它同样接受odd
和even
作为参数。
实例:
1 | body > h2:nth-of-type(n+2):nth-last-of-type(n+2) |
3.6.5.6 :first-child
伪类
和:nth-child(1)
相同。:first-child
伪类代表一个元素为其他元素的第一个子元素。
实例:
下面的例子代表了一个p
元素是div
中的第一个元素。
1 | div > p:first-child |
选择器可以匹配下面HTML中div
中的p
:
1 | <p> The last P before the note.</p> |
但是不能匹配下面div
中p
元素,因为p
不是div
中的第一个子元素。
1 | <p> The last P before the note.</p> |
3.6.5.7 :last-child
伪类
和:nth-last-child(1)
相同。:last-child
伪类代表一个元素为其他元素的最后一个子元素。
实例:
1 | ol > li:last-child |
3.6.5.8 :first-of-type
伪类
和:nth-of-type(1)
相同。:first-of-type
伪类代表一个元素,它是父元素中第一个具有相同元素名的元素。
实例:
1 | dl dt:first-of-type { |
3.6.5.9 :last-of-type
伪类
和:nth-last-of-type(1)
相同。:last-of-type
伪类代表一个元素,它是父元素中最后一个具有相同元素名的元素。
实例:
1 | tr > td:last-of-type |
3.6.5.10 :only-child
伪类
该伪类代表了一个元素,它的父元素除了它没有其他元素。其实等价于:first-child:last-child
。
3.6.5.11 :only-of-type
伪类
该伪类代表了一个元素,它的父元素除了它没有其他元素,且和指定的元素类型相同。等价于:first-of-type:last-of-type
。
3.6.5.12 :empty
伪类
:empty
伪类代表了一个元素始终没有子元素。
实例:
p:empty
可以代表以下html
片段:
1 | <p></p> |
而foo:empty
不能代表以下片段:
1 | <foo>bar</foo> |
3.6.6 空白
本节有意留为空白。(本节之前定义了一个:contains()
伪类)
3.6.7 否定伪类
否定伪类,:not(x)
是一个功能性的符号,它接受一个简单选择器作为参数。它代表了这些不是参数所代表的元素。
否定不能嵌套,:not(:not(...))
是无效的。要注意当伪元素不是简单选择器,所以它们不是:not()
的有效参数。
实例:
以下选择器匹配在HTML中没有被禁用的按钮:
1 | button:not([DISABLED]) |
默认的命名空间声明不会影响否定伪类的参数,除非该参数是一个通用选择器或类型选择器。
实例:
假设默认的命名空间为http://example.com/
,下面的选择器代表了所有不在该命名空间的元素:
1 | *|*:not(*) |
4. 伪元素
在文档语言规定之外,伪元素创建了一个关于文档树的抽象引用。例如,文档语言不提供机制来访问的一个元素的内容的第一个字母或第一行。伪元素允许作者引用这个本来无法访问的信息。伪元素还能提供作者一种方式去引用源文档中不存在的内容(::before
和::after
)。
一个伪元素是由::
跟着伪元素名称组成的。
::
符号在文档中被引入是为了在伪类和伪元素之间建立一个区别。为了与现有的样式表的兼容性,用户代理必须同样接受一个冒号:
的写法。
4.1 ::first-line
伪元素
::first-line
伪元素描述了元素的内容中被格式化的第一行。
CSS实例:
1 | p::first-line { text-transform: uppercase } |
上面的规则意思为将每个p
元素的第一行的每个字母变为大写。
注意,第一行的长度取决于许多因素,包括该页面的宽度,字体大小等。因此,一个普通的HTML段落,如:
1 | <P>This is a somewhat long HTML |
其中折行如下所示:
1 | THIS IS A SOMEWHAT LONG HTML PARAGRAPH THAT |
该段落可能可能被用户代理重写
,包括虚构的标签::first-line
。这个虚构的标签序列有助于说明属性如何继承。
1 | <P><P::first-line> This is a somewhat long HTML |
如果伪元素折断了一个真实的元素,所需的效果通常被描述为一个虚构的标签序列关闭,然后重新打开该元素。例如:
1 | <P><SPAN class="test"> This is a somewhat long HTML |
用户代理会像下面这样处理:
1 | <P><P::first-line><SPAN class="test"> This is a |
4.1.1 CSS中格式化的第一行的定义
在CSS中,::first-line
伪元素只能在block-like
容器上有效果,这些容器有block box
,inline-block
,table-caption
和table-cell
。
一个元素的格式化第一行可能发生在相同流的一个block-level
后代中(例如,一个block-level
后代没有脱离流)。例如,在<DIV><P>This line...</P></DIV>
中DIV
的第一行为p
元素的第一行。
table-cell
和inline-block
的第一行不能成为一个祖先元素的格式化的第一行。因此,在<DIV><P STYLE="display: inline-block">Hello<BR>Goodbye</P> etcetera</DIV>
中,DIV
的格式化第一行不是Hello
的那一行。
一个用户代理应当表现的就好像::first-line
的虚拟开始标签伪元素被嵌套到最内层的block-level
元素中。例如:
1 | <DIV> |
加上虚拟标签后:
1 | <DIV> |
::first-line
伪元素类似于一个inline-level
元素,但有一定的限制。以下CSS属性应用到一个::first-line
伪元素:字体属性、背景属性、颜色属性、word-spacing
,letter-spacing
,text-decoration
,vertical-align
,text-transform
,line-height
。用户代理也可能应用其他属性。
在CSS继承时,发生在第一行的子元素的一部分只从::first-line
伪元素继承::first-line
上可应用的属性。对于所有的其他属性,继承时从第一行伪元素的非鱼伪元素父元素中继承。
4.2 ::first-letter
伪元素
::first-letter
代表了一个元素的第一个字母,如果在该行中在它前面没有任何其他内容。::first-letter
伪元素可能被用于首字母大写
等用途。
标点符号,即第一个字母前面或后面也应包括在内。
当第一个字母为数字时,::first-line
也同样被应用,例如,在67 million dollars is a lot of money.
中的6
。
4.2.1 在CSS中的应用
在CSS中,::first-letter
伪元素只能在block-like
容器上有效果,这些容器有block
,list-item
,inline-block
,table-caption
和table-cell
。
::first-letter
伪元素可和所有这些包含文本的元素或有一个后代包含文本且在相同的流的元素使用。用户代理也应该表现为好像虚拟的标签被加上。
实例:
1 | <div> |
表现为:
1 | <div> |
table-cell
和inline-block
的第一个字母不能成为一个祖先元素的的第一字母。因此,在<DIV><P STYLE="display: inline-block">Hello<BR>Goodbye</P> etcetera</DIV>
中,DIV
的第一字母不是H
。实际上,DIV
没有第一个字母。
如果元素是一个list item
,::first-letter
应用在主体框标记后的第一个字母。如果list item
设置了list-style-position: inside
,用户代理将忽略该列表项的::first-letter
。如果一个元素有::before
和::after
内容,::first-letter
应用的时候包含了::before
和::after
的内容。
实例:
例如:
1 | p::before {content: "Note: "} |
p::first-letter
匹配Note
中的N
。
在CSS中,::first-letter
伪元素类似于一个inline-level
元素,如果该元素的float
为none
;否则,它和浮动元素相同。
4.3 空白
这里是故意留白的。(之前定义了::selection
伪元素)
4.4 ::before
和::after
伪元素
这两个伪元素在CSS21中定义。