目录
元素选择器
通用选择器
类选择器
也会被选中
多类选择器
ID 选择器
上下文选择器
子元素选择器
相邻元素选择器
示例
同级元素选择器
属性名选择器
属性值选择器
属性选择器对比
伪类
状态伪类选择器
:lang 选择器
结构伪类选择器
:root 选择器
:empty 伪类选择器
否定伪类选择器
伪元素
首字母伪元素选择器
首行伪元素选择器
::before/::after 伪元素选择器
::selection 伪元素选择器
参考资料
首页 web前端 html教程 精通 CSS 选择器_html/css_WEB-ITnose

精通 CSS 选择器_html/css_WEB-ITnose

Jun 24, 2016 am 11:19 AM

CSS 选择器除了样式表匹配元素时需要用到,在使用 jQuery 等库的时候也可以利用 CSS 选择器来选择元素,因此作为前端开发需要熟练掌握。下面是一些常用的 CSS 选择器示例。

元素选择器

E,选择所有指定元素名称的元素,例如 p,选择所有的 p 元素。

通用选择器

*,选择所有元素,例如:

* {  box-sizing: border-box;}
登录后复制

类选择器

.class,用一个点号加类名表示,例如 .header,选择所有 class 属性中包含 header 的元素。

<div class="header">会被选中</div><h2 id="也会被选中">也会被选中</h2>
登录后复制

多类选择器

使用多个 class 可以选择同时含有多个类名的元素,例如 .collapse.in 选择同时含有类 collapse 和 in 的元素:

<div class="collapse in">会被选中</div><div class="collapse">不会被选中</div><div class="in">不会被选中</div>
登录后复制

IE 6 浏览器不支持多类选择器,会忽略多类中前面的类,比如这里 IE 6 只会匹配 .in。

ID 选择器

#id,用一个 # 号加 ID 值表示,例如 #title,选择 id 属性等于 title 的元素。

<h2 id="title"></h2>
登录后复制

上下文选择器

selector selector,用于选择元素内部的元素,例如 p span,选择所有属于 p 元素内部的 span 元素。

<p>  <span>会被选中</span>  <strong><span>同样会被选中</span></strong></p>
登录后复制

子元素选择器

selector > selector,用于选择带有特定父元素的元素,例如 p > span,选择所有父元素为 p 的 span 元素。

<p>  <span>父元素是 p 会被选中</span>  <strong><span>父元素是 strong 不会被选中</span></strong></p>
登录后复制

相邻元素选择器

selector + selector,用于选择一个特定元素之后紧跟的元素,h2 + p,选择所有相邻 h2 元素之后的同级 p 元素。

<div>  <p>h2 之前的不会被选中</p>  <h2 id="示例">示例</h2>  <p>紧邻 h2 的会被选中</p>  <p>不会被选中</p></div>
登录后复制

同级元素选择器

selector ~ selector,用于选择特定元素之后的同级元素,h2 ~ p,选择所有 h2 元素之后的同级 p 元素。

<div>  <p>不会被选中</p>  <h2 id="示例">示例</h2>  <p>h2 之后的同级 p 元素会被选中</p>  <span>示例</span>  <p>h2 之后的同级 p 元素会被选中</p></div>
登录后复制

同级元素选择器选择特定元素之后的所有同级元素,而相邻元素选择器只选择特定元素之后紧邻的那个元素。

属性名选择器

[attribute],用于选择所有带有特定属性的元素,例如 [title],选择所有带有 title 属性的元素。

<a title="link">会被选中</a><a>不会被选中</a>
登录后复制

属性值选择器

[attribute="value"],用于选择所有带有特定属性和值的元素,例如 [title="link"],选择所有带有 title 属性并且值为 link 的元素。

<a title="link">会被选中</a><a title="this is a link">属性值不匹配,不会被选中</a>
登录后复制

[attribute~="value"],用于选择所有带有特定属性并且属性值包含指定单词的元素,单词之间用空格分隔,例如 [title~="link"],选择所有带有 title 属性并且属性值中包含 link 单词的元素。

<a title="link">会被选中</a><a title="this is a link">属性值中包含 link 会被选中</a><a title="thisisalink">不会被选中</a><a title="other">不会被选中</a>
登录后复制

[attribute|="value"],用于选择带有特定属性并且属性值是以指定值开头的所有元素,该值必须是整个单词,或者后面跟着连字符,例如 [title|="red"],选择所有带有 title 属性并且值是 red 开头的元素。

<a title="red">会被选中</a><a title="red-hot">会被选中</a><a title="redhot">不会被选中</a>
登录后复制

[attribute^="value"],用于选择带有特定属性并且属性值是以指定字符串开头的所有元素,例如 a[href^="http://"],选择所有 href 属性值以 http:// 字符串开头的 a 元素。

<a href="http://www.baidu.com/">会被选中</a><a href="/index">不会被选中</a>
登录后复制

[attribute$="value"],用于选择带有特定属性并且属性值是以指定字符串结尾的所有元素,例如 img[src$=".png"],选择所有 png 格式的 img 元素。

<img src="/static/imghw/default1.png"  data-src="/assets/logo.png"  class="lazy"  alt="logo"> <!-- 会被选中 --><img src="/static/imghw/default1.png"  data-src="/assets/banner.jpg"  class="lazy"  alt="banner"> <!-- 不会被选中 -->
登录后复制

[attribute*="value"],用于选择带有特定属性并且属性值包含指定字符串的所有元素,例如 [title*="red"],选择所有带有 title 属性并且值包含 red 字符串的所有元素。

<a title="red">会被选中</a><a title="redhot">会被选中</a><a title="hotredhot">会被选中</a>
登录后复制

属性选择器对比

选择器 属性值
[attribute] 仅匹配属性名,与属性值无关
[attribute="value"] 完全匹配属性名和属性值
[attribute~="value"] 属性值以空格分隔,包含 value 单词或者仅为 value
[attribute管道符="value"] 属性值以 value- 开头或者仅为 value
[attribute^="value"] 属性值以 value 字符串开头
[attribute$="value"] 属性值以 value 字符串结尾
[attribute*="value"] 属性值包含 value 字符串

伪类

状态伪类选择器

状态伪类选择器会根据元素的特定状态选择相应的元素。

选择器 说明 例子
:link 选择所有未被访问的链接 a:link
:visited 选择所有已被访问的链接 a:visited
:focus 选择获取焦点的元素 input:focus
:hover 择鼠标指针位于其上的元素 li:hover
:active 选择激活的元素 button:active

:target,选择目标元素。当用户点击一个指向页面中其它元素的链接,则那个被指向的元素就是目标元素,例如:

<a href="#more">more</a> <!-- 点击这个链接之后 --><div id="more">...</div> <!-- 这个元素会被 :target 选中 -->
登录后复制

:enabled,选择所有已启用的元素。

<input type="text"> <!-- 会被选中 --><input disabled type="text"> <!-- 已禁用不会被选中 -->
登录后复制

:disabled,选择所有被禁用的元素,和 :enabled 相反,例如:

input[type="text"]:disabled {  background-color: #eee;}
登录后复制

给禁用的文本输入框一个灰色的背景。

<input type="text"> <!-- 不会被选中 --><input disabled type="text"> <!-- 禁用的文本框会被选中 -->
登录后复制

:checked,选择所有已经被勾选的单选框或者复选框,例如 input:checked。

<input checked type="radio"> <!-- 已经勾选的元素会被选中 --><input type="checkbox"> <!-- 没有勾选的不会被选中 -->
登录后复制

示例,结合属性选择器选择被勾选的单选框:input[type="radio"]:checked。

:lang 选择器

:lang(language),用于选择所有带有以指定值开头的 lang 属性的元素,例如 p:lang(en)。

<p lang="en">会被选中</p><p lang="en-US">会被选中</p>
登录后复制

该选择器等同于 [lang|="language"],是 [attribute|="value"] 选择器的一种特例。

结构伪类选择器

:nth-child(n),选择同级元素中的第 n 个元素,例如 ul > li:nth-child(2):

<ul>  <li>不会被选中</li>  <li>第二个元素会被选中</li>  <li>不会被选中</li></ul>
登录后复制

需要注意的是子元素的下标是从 1 开始的。除了可以指定特定的数字,也可以使用 even(偶数), odd(奇数) 关键字,例如 ul > li:nth-child(odd),或者使用公式,例如 ul > li:nth-child(2n+1)(n 是计数器,从 0 开始):

<ul>  <li>第一个子元素会被选中</li>  <li>第二个子元素不会被选中</li>  <li>第三个子元素会被选中</li></ul>
登录后复制

:nth-last-child(n),同上,不过是从最后一个子元素开始计数,使用该选择器可以实现隔行变色的效果。

:first-child,选择同级元素中的第一个元素,例如 ul > li:first-child:

<ul>  <li>会被选中</li>  <li>不会被选中</li>  <li>不会被选中</li></ul>
登录后复制

作用等同于 ul > li:nth-child(1)。

:last-child,选择同级元素中的最后一个元素,例如 ul > li:last-child:

<ul>  <li>不会被选中</li>  <li>不会被选中</li>  <li>会被选中</li></ul>
登录后复制

作用等同于 ul > li:nth-last-child(1)。

:only-child,用于选择父元素下唯一的子元素,例如 ul > li:only-child:

<ul>  <li>唯一子元素,会被选中</li></ul><ul>  <li>不会被选中</li>  <li>不会被选中</li></ul>
登录后复制

:nth-of-type(n),选择同级元素中的第 n 个同类元素,和 :nth-child 类似,例如 .box > :nth-of-type(2):

<div class="box">  <p>第一个 p 子元素,不会被选中</p>  <span>第一个 span 子元素,不会被选中</span>  <p>第二个 p 子元素,会被选中</p>  <span>第二个 span 子元素,会被选中</span></div>
登录后复制

:nth-last-of-type,同上,不过是从最后一个同类子元素开始计数。

:first-of-type,选择同级元素中的第一个同类元素,等同于 :nth-of-type(1)。

:last-of-type,选择同级元素中的最后一个同类元素,等同于 nth-last-of-type(1)。

:only-of-type,用于选择父元素下特定类型的唯一子元素,例如 .box > :only-of-type:

<div class="box">  <p>不会被选中</p>  <em>唯一的 em 子元素会被选中</em>  <p>不会被选中</p>  <span>唯一的 span 子元素会被选中</span></div>
登录后复制

:root 选择器

:root,选择文档的根元素,对于 HTML 文档就是 html 元素。

:empty 伪类选择器

:empty,选择没有子元素的元素(包括文本节点),例如:

p:empty {  display: none;}
登录后复制

表示隐藏没有内容的 p 元素,

<p>非空不会被选中</p><p></p> <!-- 为空会被选中 -->
登录后复制

否定伪类选择器

:not(selector),选择所有不匹配选择器的元素,例如 :not(p),选择所有不为 p 的元素:

<p>不会被选中</p><span>会被选中</span>
登录后复制

要选择既不是 p 也不是 span 的元素可以多次使用否定伪类选择器,例如 :not(p):not(span),需要同时满足条件的元素才会被选中。

CSS 4 否定伪类选择器支持传入参数列表,比如 :not(p, span)。

伪元素

伪元素选择器用于选择那些若有实无的元素。在 CSS3 中,伪元素的写法为两个冒号,为了兼容旧浏览器,也可以使用一个冒号。

首字母伪元素选择器

::first-letter,选择元素的第一个字母,例如:

p::first-letter {  font-size: 300%;}
登录后复制

段落元素的首字母放大。

首行伪元素选择器

::first-line,选择元素的第一行,例如:

p::first-line {  text-decoration: underline;}
登录后复制

段落元素的首行添加下划线。

::before/::after 伪元素选择器

::before,选择在元素之前插入的生成内容。

::after,选择在元素之后插入的生成内容,例如:

<blockquote>Lorem ipsum dolor sit amet.</blockquote>
登录后复制

和样式:

blockquote::before {  content: "\0022";}blockquote::after {  content: "\0022";}
登录后复制

::selection 伪元素选择器

::selection,选择用户选取的内容,例如:

::selection {  background: #b3d4fc;  text-shadow: none;}
登录后复制

参考资料

  • ::first-letter CSS pseudo-element selector
  • ::selection CSS pseudo-element
  • CSS 2.1 selectors
  • CSS3 selectors
  • 本站声明
    本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

    热AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智能驱动的应用程序,用于创建逼真的裸体照片

    AI Clothes Remover

    AI Clothes Remover

    用于从照片中去除衣服的在线人工智能工具。

    Undress AI Tool

    Undress AI Tool

    免费脱衣服图片

    Clothoff.io

    Clothoff.io

    AI脱衣机

    AI Hentai Generator

    AI Hentai Generator

    免费生成ai无尽的。

    热门文章

    R.E.P.O.能量晶体解释及其做什么(黄色晶体)
    3 周前 By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O.最佳图形设置
    3 周前 By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O.如果您听不到任何人,如何修复音频
    3 周前 By 尊渡假赌尊渡假赌尊渡假赌

    热工具

    记事本++7.3.1

    记事本++7.3.1

    好用且免费的代码编辑器

    SublimeText3汉化版

    SublimeText3汉化版

    中文版,非常好用

    禅工作室 13.0.1

    禅工作室 13.0.1

    功能强大的PHP集成开发环境

    Dreamweaver CS6

    Dreamweaver CS6

    视觉化网页开发工具

    SublimeText3 Mac版

    SublimeText3 Mac版

    神级代码编辑软件(SublimeText3)

    &gt; gt;的目的是什么 元素? &gt; gt;的目的是什么 元素? Mar 21, 2025 pm 12:34 PM

    本文讨论了HTML&lt; Progress&gt;元素,其目的,样式和与&lt; meter&gt;元素。主要重点是使用&lt; progress&gt;为了完成任务和LT;仪表&gt;对于stati

    &lt; datalist&gt;的目的是什么。 元素? &lt; datalist&gt;的目的是什么。 元素? Mar 21, 2025 pm 12:33 PM

    本文讨论了html&lt; datalist&gt;元素,通过提供自动完整建议,改善用户体验并减少错误来增强表格。Character计数:159

    &lt; meter&gt;的目的是什么。 元素? &lt; meter&gt;的目的是什么。 元素? Mar 21, 2025 pm 12:35 PM

    本文讨论了HTML&lt; meter&gt;元素,用于在一个范围内显示标量或分数值及其在Web开发中的常见应用。它区分了&lt; meter&gt;从&lt; progress&gt;和前

    视口元标签是什么?为什么对响应式设计很重要? 视口元标签是什么?为什么对响应式设计很重要? Mar 20, 2025 pm 05:56 PM

    本文讨论了视口元标签,这对于移动设备上的响应式Web设计至关重要。它解释了如何正确使用确保最佳的内容缩放和用户交互,而滥用可能会导致设计和可访问性问题。

    我如何使用html5&lt; time&gt; 元素以语义表示日期和时间? 我如何使用html5&lt; time&gt; 元素以语义表示日期和时间? Mar 12, 2025 pm 04:05 PM

    本文解释了HTML5&lt; time&gt;语义日期/时间表示的元素。 它强调了DateTime属性对机器可读性(ISO 8601格式)的重要性,并在人类可读文本旁边,增强Accessibilit

    HTML5中跨浏览器兼容性的最佳实践是什么? HTML5中跨浏览器兼容性的最佳实践是什么? Mar 17, 2025 pm 12:20 PM

    文章讨论了确保HTML5跨浏览器兼容性的最佳实践,重点是特征检测,进行性增强和测试方法。

    如何使用HTML5表单验证属性来验证用户输入? 如何使用HTML5表单验证属性来验证用户输入? Mar 17, 2025 pm 12:27 PM

    本文讨论了使用HTML5表单验证属性,例如必需的,图案,最小,最大和长度限制,以直接在浏览器中验证用户输入。

    &lt; iframe&gt;的目的是什么。 标签?使用时的安全考虑是什么? &lt; iframe&gt;的目的是什么。 标签?使用时的安全考虑是什么? Mar 20, 2025 pm 06:05 PM

    本文讨论了&lt; iframe&gt;将外部内容嵌入网页,其常见用途,安全风险以及诸如对象标签和API等替代方案的目的。

    See all articles