九、CSS选择器


前情提要:伪类和伪元素

在CSS中,确实存在使用单个冒号(:)和双冒号(::)的区别,这主要涉及到伪类选择器和伪元素选择器的不同。

  1. 单个冒号(:):用于伪类选择器,比如 :hover, :first-child, :active 等。伪类用于定义元素的特殊状态。

示例:

a:hover {
  color: red;
}
  1. 双冒号(::):用于伪元素选择器,这是CSS3中的语法,用来创建一些不在文档树中的元素。常见的伪元素包括 ::before, ::after, ::first-letter, ::first-line 等。

示例:

p::before {
  content: "注意:";
  color: blue;
}

在CSS2中,伪元素使用单冒号(比如 :before),但CSS3规范推荐使用双冒号来区分伪类和伪元素。这样做主要是为了增强代码的清晰度和语义性,使得CSS的维护和开发更加直观。尽管如此,大多数现代浏览器仍然支持使用单冒号来表示伪元素,为了最好的兼容性和遵循最新标准,建议使用双冒号表示伪元素。

总结,单冒号用于伪类,双冒号用于伪元素,这是两者基本的区别。按照CSS3的规定,建议遵循这一区分。

说到这顺便看戏CSS的选择器有哪些:

CSS 选择器是用于选择要设置样式的 HTML 元素的模式。CSS 提供了多种类型的选择器,不同的选择器可以根据不同的条件来选定元素。以下是一些常见的CSS选择器类型及其用法示例:

1. 基础选择器

  • 通配选择器(Universal Selector)*,选择所有元素。
  • 元素类型选择器(Type Selector):如 divp,选择所有指定类型的元素。
  • 类选择器(Class Selector).classname,选择具有特定类的元素。
  • ID选择器(ID Selector)#idname,选择具有特定ID的元素。
  • 属性选择器(Attribute Selector):如 [type=”text”],选择具有特定属性的元素。

2. 组合选择器

  • 后代选择器(Descendant Selector)A B,选择A元素内部的所有B元素。
  • 子选择器(Child Selector)A > B,选择A元素直接子元素中的B元素。
  • 相邻兄弟选择器(Adjacent Sibling Selector)A + B,选择紧接在A元素后的第一个兄弟元素B。
  • 通用兄弟选择器(General Sibling Selector)A ~ B,选择A元素后的所有兄弟元素B。

3. 伪类选择器(Pseudo-class Selector)

  • 链接伪类:link:visited,选择链接元素不同的状态。
  • 用户动作伪类:hover:active:focus,选择元素在用户交互时的状态。
  • 结构伪类:如:first-child:last-child:nth-child(n),选择特定位置的元素。

4. 伪元素选择器(Pseudo-element Selector)

  • ::before::after:在元素内容前后添加内容。
  • ::first-line::first-letter:选择文本的第一行或第一个字母。

5. 属性选择器

  • 存在和值属性选择器[attr][attr=value],选择具有属性或指定值的属性的元素。
  • 包含子串的属性选择器[attr*=value][attr^=value][attr$=value],分别选择属性值包含子串、以子串开头、以子串结尾的元素。

6. 否定选择器

  • 否定伪类:not(selector),选择不匹配给定选择器的每个元素。

这些选择器可以单独使用,也可以组合使用来定位HTML文档中的元素。正确使用选择器对于编写高效、易维护的CSS代码至关重要。


文章作者: 吴俊杰
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 吴俊杰 !
  目录