伪类和伪元素,对于绝大多数同窗来讲,都是耳熟能详的名字,但确实又有不少人搞不清楚它们之间的区别,以至于混淆概念。而当概念都混淆的时候,也每每意味着你不会常常使用它,怕出错,怕用很差。而这也会大大影响你的效率,原本几行代码就能够完成的工做,却要写上一大堆......因此,花点时间理清楚每个看似微小的概念,会让咱们的编程更有效率。下面进入正题。express
伪类和伪元素的区别,其实很简单,从字面上就能够理解。它们有一个共同的修饰词“伪”,那么“伪”是什么意思呢?就是假的呗。因此,伪类就是假的类,伪元素就是假的元素,这就是在字面上它们之间的区别。下面咱们再从定义上感觉一下。编程
CSS3给出的定义是:ide
The pseudo-class concept is introduced to permit selection based on information that lies outside of the document tree or that cannot be expressed using the other simple selectors.
大体翻译过来的意思就是:伪类存在的意义是为了经过选择器,格式化DOM树之外的信息以及不能被常规CSS选择器获取到的信息。this
经过上面的概念咱们知道了伪类的功能有两种:spa
1.格式化DOM树之外的信息。好比:<a>
标签的:link、:visited
等。这些信息不存在于DOM树中。翻译
2.不能被常规CSS选择器获取到的信息。好比:要获取第一个子元素,咱们没法用常规的CSS选择器获取,但能够经过:first-child
来获取到。code
CSS3给出的定义以下:orm
Pseudo-elements create abstractions about the document tree beyond those specified by the document language. For instance, document languages do not offer mechanisms to access the first letter or first line of an element's content. Pseudo-elements allow authors to refer to this otherwise inaccessible information. Pseudo-elements may also provide authors a way to refer to content that does not exist in the source document (e.g., the ::before and ::after pseudo-elements give access to generated content).
大体翻译过来的意思就是:伪元素能够建立一些文档语言没法建立的虚拟元素。好比:文档语言没有一种机制能够描述元素内容的第一个字母或第一行,但伪元素能够作到(::first-letter、::first-line
)。同时,伪元素还能够建立源文档不存在的内容,好比使用::before
或 ::after
。图片
经过上面的概念,咱们就能够知道伪类与伪元素最本质的一个区别:ci
伪类实际上是弥补了CSS选择器的不足,用来更方便地获取信息;
HTML:
<ul> <li>11111</li> <li>22222</li> </ul>
CSS:
li:first-child { color: red; } // 选择器不能直接选取第一个子元素 // 伪类弥补了选择器的不足
而伪元素本质上是建立了一个虚拟容器(元素),咱们能够在其中添加内容或样式。
HTML:
<p> <span class="first-letter">H</span>ello, World </p>
CSS:
.first-letter { color: red; }
上面的代码其实就是:
p::first-letter { color: red; }
因此,你能够理解伪元素本质上是建立了一个虚拟容器(元素)了吧。
除了上面这个本质区别之外,在CSS3中,伪类用单冒号:
表示;而伪元素用双冒号::
表示。一个选择器能够同时使用多个伪类(但有的伪类会互斥);而一个选择器只能同时使用一个伪元素(将来的版本可能会支持多伪元素)。
1 :first-child
匹配第一个子元素。
HTML:
<ul> <li>111</li> <li>222</li> </ul>
CSS:
li:first-child { color: red; // 第一个 li 会变红 }
2 :last-child
匹配最后一个子元素。
HTML:
<ul> <li>aaa</li> <li>bbb</li> <li>ccc</li> </ul>
CSS:
li:last-child { color:red; // 最后一个 li 会变红 }
3 :first-of-type
匹配属于其父元素的第一个特定类型的子元素。
HTML:
<div> <h1>h1文本</h1> <p>p文本</p> </div>
CSS:
p:first-of-type { color: red; // <p>标签的内容变为红色 }
这里有必要强调一下:first-child
与:first-of-type
的区别。若是你的CSS写成:
p:first-child { color:red; }
页面是不会有变化的,由于<p>元素并非父元素<div>的第一个子元素。
4 :last-of-type
匹配属于其父元素的最后一个特定类型的子元素。
HTML:
<div> <h1>h1文本</h1> <h1>h1文本2</h1> <p>p文本</p> </div>
CSS:
h1:last-of-type { color: red; // 倒数第一个<h1>标签的内容变为红色(h1文本2) }
1 ::before
在被选元素以前插入内容。须要指定content属性来插入内容。
HTML:
<p>CSS</p>
CSS:
p::before { content: "Hi,"; }
2 ::after
在被选元素以后插入内容。须要指定content属性来插入内容。
HTML:
<p>Hi, </p>
CSS:
p::after { content: "CSS"; }
3 ::first-letter
匹配元素中文本的首字母。
HTML:
<p>我在学伪元素</p>
注意:试试把<p>
标签改为<p>???我在学伪元素</p>
,你会发现颇有意思的现象。
CSS:
p::first-letter { font-size: 32px; }
4 ::first-line
匹配元素中第一行的文本(只能在块元素中使用)。
HTML:
<p>我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素</p>
CSS:
p::first-line { color: red; }
5 ::selection
匹配被用户选中的部分。
HTML:
<p>我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素</p>
CSS:
p::selection { color: red; }
最后的最后,我说的不必定都对,你必定要本身试试!
(本文完)