0

0

这些CSS选择器 你必须记在脑袋里!

伊谢尔伦

伊谢尔伦

发布时间:2016-11-22 15:18:23

|

1763人浏览过

|

来源于php中文网

原创

 大概大家都知道id,class以及descendant选择器,并且整体都在使用它们,那么你正在错误拥有更大级别的灵活性的选择方式。这篇文章里面提到的大部分选择器都是在css3标准下的,所以它们只能在相应最新版本的浏览器中才能生效,你完全应该把这些都记在你聪明的脑袋里面。

1. *

* {
  margin: 0;
  padding: 0;
}

  在我们看比较高级的选择器之前,应该认识下这个众所周知的清空选择器。星号呢会将页面上所有每一个元素都选到。许多开发者都用它来清空margin和padding。当然你在练习的时候使用这个没问题,但是我不建议在生产环境中使用它。它会给浏览器凭添许多不必要的东西。

*也可以用来选择某元素的所有子元素。

#container * {
  border: 1px solid black;
}

    它会选中#container下的所有元素。当然,我还是不建议你去使用它,如果可能的话。

立即学习前端免费学习笔记(深入)”;

  DEMO

  兼容性

IE6+

Firefox

Chrome

Safari

Opera

 2. #X

#container {
   width: 960px;
   margin: auto;
}

  在选择器中使用#可以用id来定位某个元素。大家通常都会这么使用,然后使用的时候大家还是得相当小心的。

需要问自己一下:我是不是必须要给这个元素来赋值个id来定位它呢?

  id选择器是很严格的并且你没办法去复用它。如果可能的话,首先试试用标签名字,HTML5中的新元素,或者是伪类。

  DEMO

  兼容性

IE6+

Firefox

Chrome

Safari

Opera

3. .X

.error {
  color: red;
}

  这是个class选择器。它跟id选择器不同的是,它可以定位多个元素。当你想对多个元素进行样式修饰的时候就可以使用class。当你要对某个特定的元素进行修饰那就是用id来定位它。

  DEMO

  兼容性

IE6+

Firefox

Chrome

Safari

Opera

4. X Y

li a {
  text-decoration: none;
}

    下一个常用的就是descendant选择器。如果你想更加具体的去定位元素,你可以使用它。例如,假如,你不需要定位所有的a元素,而只需要定位li标签下的a标签?这时候你就需要使用descendant选择器了。

  专家提示:如果你的选择器像X Y Z A B.error这样,那你就错了。时刻都提醒自己,是否真的需要对那么多元素修饰。

  DEMO

  兼容性

IE6+

Firefox

Chrome

Safari

Opera

5. X

a { color: red; }
ul { margin-left: 0; }

    如果你想定位页面上所有的某标签,不是通过id或者是’class’,这简单,直接使用类型选择器。

  DEMO

  兼容性

IE6+

Firefox

Chrome

Safari

Opera

6. X:visited and X:link

a:link {color:red;}
a:visited {color: purple;}

    我们使用:link这个伪类来定位所有还没有被访问过的链接。

  另外,我们也使用:visited来定位所有已经被访问过的链接。

  DEMO

  兼容性

IE7+

Firefox

Chrome

Safari

Opera

7. X+Y

ul + p {
   color: red;
}

     这个叫相邻选择器。它指挥选中指定元素的直接后继元素。上面那个例子就是选中了所有ul标签后面的第一段,并将它们的颜色都设置为红色。

  DEMO

  兼容性

IE7+

Firefox

Chrome

Safari

Opera

8. X>Y

div#container > ul {
  border: 1px solid black;
}

     X Y和X > Y的差别就是后面这个指挥选择它的直接子元素。看下面的例子:

<div id="container">
   <ul>
      <li> List Item
        <ul>
           <li> Child </li>
        </ul>
      </li>
      <li> List Item </li>
      <li> List Item </li>
      <li> List Item </li>
   </ul>
</div>

    #container > ul只会选中id为’container’的div下的所有直接ul元素。它不会定位到如第一个li下的ul元素。

  由于某些原因,使用子节点组合选择器会在性能上有许多的优势。事实上,当在javascript中使用css选择器时候是强烈建议这么做的。

  DEMO

  兼容性

IE7+

Firefox

Chrome

Safari

Opera

9. X ~ Y

ul ~ p {
  color: red;
}

    兄弟节点组合选择器跟X+Y很相似,然后它又不是那么的严格。ul + p选择器只会选择紧挨跟着指定元素的那些元素。而这个选择器,会选择跟在目标元素后面的所有匹配的元素。

  DEMO

  兼容性

IE7+

Firefox

Chrome

Safari

Opera

10. X[title]

a[title] {
  color: green;
}

    这个叫属性选择器,上面的这个例子中,只会选择有title属性的元素。那些没有此属性的锚点标签将不会被这个代码修饰。那再想想如果你想更加具体的去筛选?那…

  DEMO

  兼容性

IE7+

Firefox

Chrome

Safari

Opera

11. X[href="foo"]

a[href="http://strongme.cn"] {
  color: #1f6053; /* nettuts green */
}

   上面这片代码将会把href属性值为http://strongme.cn的锚点标签设置为绿色,而其他标签则不受影响。

注意我们将值用双引号括起来了。那么在使用Javascript的时候也要使用双引号括起来。可以的话,尽量使用标准的CSS3选择器。

  这样可以用了,但是还是有点死,如果不是这个链接,而是类似的链接,那么这时就得用正则表达式了。

  DEMO

  兼容性

IE7+

Firefox

Chrome

Safari

Opera

12. X[href*="strongme"]

a[href*="strongme"] {
  color: #1f6053;
}

    Tada,正是我们需要的,这样,就指定了strongme这个值必须出现在锚点标签的href属性中,不管是strongme.cn还是strongme.com还是www.strongme.cn都可以被选中。

但是记得这是个很宽泛的表达方式。如果锚点标签指向的不是strongme相关的站点,如果要更加具体的限制的话,那就使用^和$,分别表示字符串的开始和结束。

  DEMO

  兼容性

IE7+

Firefox

Chrome

Safari

Opera

13. X[href^="href"]

a[href^="http"] {
   background: url(path/to/external/icon.png) no-repeat;
   padding-left: 10px;
}

    大家肯定好奇过,有些站点的锚点标签旁边会有一个外链图标,我也相信大家肯定见过这种情况。这样的设计会很明确的告诉你会跳转到别的网站。

用克拉符号就可以轻易做到。它通常使用在正则表达式中标识开头。如果我们想定位锚点属性href中以http开头的标签,那我们就可以用与上面相似的代码。

注意我们没有搜索http://,那是没必要的,因为它都不包含https://。

  那如果我们想找到所有指向一张图片的锚点标签呢?那我们来使用下&字符。

  DEMO

  兼容性

IE7+

Firefox

Chrome

Safari

Opera

14. X[href$=".jpg"]

a[href$=".jpg"] {
  color: red;
}

 这次我们又使用了正则表达式$,表示字符串的结尾处。这段代码的意思就是去搜索所有的图片链接,或者其它链接是以.jpg结尾的。但是记住这种写法是不会对gifs和pngs起作用的。

  DEMO

  兼容性

IE7+

Firefox

Chrome

Safari

Opera

15. X[data-*="foo"]

a[data-filetype="image"] {
   color: red;
}

   在回到第8条,我们如何把所有的图片类型都选中呢png,jpeg,’jpg’,’gif’?我们可以使用多选择器。看下面:

a[href$=".jpg"],
a[href$=".jpeg"],
a[href$=".png"],
a[href$=".gif"] {
   color: red;
}

    但是这样写着很蛋疼啊,而且效率会很低。另外一个办法就是使用自定义属性。我们可以给每个锚点加个属性data-filetype指定这个链接指向的图片类型。

<a href="path/to/image.jpg" data-filetype="image"> Image Link </a>

    那有了这个钩子,我们就可以去用标准的办法只去选定文件类型为image的锚点了。

a[data-filetype="image"] {
   color: red;
}

    DEMO

  兼容性

IE7+

Firefox

Chrome

Safari

Opera

16. X[foo~="bar"]

a[data-info~="external"] {
   color: red;
}
a[data-info~="image"] {
   border: 1px solid black;
}

 这个我想会让你的小伙伴惊呼妙极了。很少有人知道这个技巧。这个~符号可以定位那些某属性值是空格分隔多值的标签。

继续使用第15条那个例子,我们可以设置一个data-info属性,它可以用来设置任何我们需要的空格分隔的值。这个例子我们将指示它们为外部连接和图片链接。

<a href="path/to/image.jpg" data-info="external image"> Click Me, Fool </a>

    给这些元素设置了这个标志之后,我们就可以使用~来定位这些标签了。

/* Target data-info attr that contains the value "external" */
a[data-info~="external"] {
   color: red;
}
 
/* And which contain the value "image" */
a[data-info~="image"] {
  border: 1px solid black;
}

17. X:checked

input[type=radio]:checked {
   border: 1px solid black;
}

   上面这个伪类写法可以定位那些被选中的单选框和多选框,就是这么简单。

Tome
Tome

先进的AI智能PPT制作工具

下载

  DEMO

  兼容性

IE9+

Firefox

Chrome

Safari

Opera

 18. X:after

  before和after这俩伪类。好像每天大家都能找到使用它们的创造性方法。它们会在被选中的标签周围生成一些内容。
当使用.clear-fix技巧时许多属性都是第一次被使用到里面的。

.clearfix:after {
    content: "";
    display: block;
    clear: both;
    visibility: hidden;
    font-size: 0;
    height: 0;
  }
 
.clearfix {
   *display: inline-block;
   _height: 1%;
}

    上面这段代码会在目标标签后面补上一段空白,然后将它清除。这个方法你一定得放你的聚宝盆里面。特别是当overflow:hidden方法不顶用的时候,这招就特别管用了。

还想看其他创造性的使用这个伪类,看这里。

根据CSS3标准规定,可以使用两个冒号`::`。然后为了兼容性,浏览器也会接受一个双引号的写法。其实在这个情况下,用一个冒号还是比较明智的。

  兼容性

IE8+

Firefox

Chrome

Safari

Opera

19. X::hover

div:hover {
  background: #e3e3e3;
}

    不用说,大家肯定知道它。官方的说法是user action pseudo class.听起来有点儿迷糊,其实还好。如果想在用户鼠标飘过的地方涂点儿彩,那这个伪类写法可以办到。

注意旧版本的IE只会对加在锚点`a`标签上的`:hover`伪类起作用。

  通常大家在鼠标飘过锚点链接时候加下边框的时候用到它。

a:hover {
 border-bottom: 1px solid black;
}

    专家提示:border-bottom:1px solid black;比text-decoration:underline;要好看很多。

  兼容性

IE6+(IE6只能在锚点标签上起作用)

Firefox

Chrome

Safari

Opera

 20. X:not(selector)

div:not(#container) {
   color: blue;
}

    取反伪类是相当有用的,假设我们要把除id为container之外的所有div标签都选中。那上面那么代码就可以做到。

  或者说我想选中所有出段落标签之外的所有标签。

*:not(p) {
  color: green;
}

    DEMO

  兼容性

IE9+

Firefox

Chrome

Safari

Opera

21. X::pseudoElement

p::first-line {
  font-weight: bold;
  font-size:1.2em;
}

    我们可以使用::来选中某标签的部分内容,如地一段,或者是第一个字没有。但是记得必须使用在块式标签上才起作用。

伪标签是由两个冒号`::`组成的。

  定位第一个字

p::first-letter {
   float: left;
   font-size: 2em;
   font-weight: bold;
   font-family: cursive;
   padding-right: 2px;
}

    上面这段代码会找到页面上所有段落,并且指定为每一段的第一个字。

  它通常在一些新闻报刊内容的重点突出会使用到。

  定位某段的第一行

p::first-line {
   font-weight: bold;
   font-size: 1.2em;
}

    跟::first-line相似,会选中段落的第一行 。

  为了兼容性,之前旧版浏览器也会兼容单冒号的写法,例如:first-line,:first-letter,:before,:after.但是这个兼容对新介绍的特性不起作用。

  DEMO

  兼容性

IE6+

Firefox

Chrome

Safari

Opera

22. X:nth-child(n)

li:nth-child(3) {
   color: red;
}

    还记得我们面对如何取到推跌式标签的第几个元素是无处下手的时光么,有了nth-child那日子就一去不复返了。

  请注意nth-child接受一个整形参数,然后它不是从0开始的。如果你想获取第二个元素那么你传的值就是li:nth-child(2).

  我们甚至可以获取到由变量名定义的个数个子标签。例如我们可以用li:nth-child(4n)去每隔3个元素获取一次标签。

  DEMO

  兼容性

IE9+

Firefox3.5+

Chrome

Safari

23. X:nth-last-child(n)

li:nth-last-child(2) {
   color: red;
}

    假设你在一个ul标签中有N多的元素,而你只想获取最后三个元素,甚至是这样li:nth-child(397),你可以用nth-last-child伪类去代替它。

  这个技巧可以很正确的代替第16个TIP,不同的就是它是从结尾处开始的,倒回去的。

  DEMO

  兼容性

IE9+

Firefox3.5+

Chrome

Safari

Opera

24. X:nth-of-type(n)

ul:nth-of-type(3) {
   border: 1px solid black;
}

    曾几何时,我们不想去选择子节点,而是想根据元素的类型来进行选择。

  想象一下有5个ul标签。如果你只想对其中的第三个进行修饰,而且你也不想使用id属性,那你就可以使用nth-of-type(n)伪类来实现了,上面的那个代码,只有第三个ul标签会被设置边框。

  DEMO

  兼容性

IE9+

Firefox3.5+

Chrome

Safari

25. X:nth-last-of-type(n)

ul:nth-last-of-type(3) {
   border: 1px solid black;
}

    同样,也可以类似的使用nth-last-of-type来倒序的获取标签。

  兼容性

IE9+

Firefox3.5+

Chrome

Safari

Opera

  26. X:first-child

ul li:first-child {
   border-top: none;
}

这个结构性的伪类可以选择到第一个子标签,你会经常使用它来取出第一个和最后一个的边框。

  假设有个列表,没个标签都有上下边框,那么效果就是第一个和最后一个就会看起来有点奇怪。这时候就可以使用这个伪类来处理这种情况了。

  DEMO

  兼容性

IE7+

Firefox

Chrome

Safari

Opera

27. X:last-child

ul > li:last-child {
   color: green;
}

    跟first-child相反,last-child取的是父标签的最后一个标签。

  例如标签

<ul>
   <li> List Item </li>
   <li> List Item </li>
   <li> List Item </li>
</ul>
 ul {
 width: 200px;
 background: #292929;
 color: white;
 list-style: none;
 padding-left: 0;
}
 li {
 padding: 10px;
 border-bottom: 1px solid black;
 border-top: 1px solid #3c3c3c;
}

    上面的代码将设置背景色,移除浏览器默认的内边距,为每个li设置边框以凸显一定的深度。

  DEMO

  兼容性

IE9+

Firefox

Chrome

Safari

Opera

28. X:only-child

div p:only-child {
   color: red;
}

    说实话,你会发现你几乎都不会用到这个伪类。然而,它是可用的,有会需要它的。

  它允许你获取到那些只有一个子标签的父标签。就像上面那段代码,只有一个段落标签的div才被着色。

<div><p> My paragraph here. </p></div> 
<div>
   <p> Two paragraphs total. </p>
   <p> Two paragraphs total. </p>
</div>

    上面例子中,第二个div不会被选中。一旦第一个div有了多个子段落,那这个就不再起作用了。

  DEMO

  兼容性

IE9+

Firefox

Chrome

Safari

Opera

29. X:only-of-type

li:only-of-type {
   font-weight: bold;
}

    结构性伪类可以用的很聪明。它会定位某标签只有一个子标签的目标。设想你想获取到只有一个子标签的ul标签?

  使用ul li会选中所有li标签。这时候就要使用only-of-type了。

ul > li:only-of-type {
   font-weight: bold;
}

     DEMO

  兼容性

IE9+

Firefox 3.5+

Chrome

Safari

Opera

30. X:first-of-type

  first-of-type伪类可以选择指定标签的第一个兄弟标签。

  测试

<div>
   <p> My paragraph here. </p>
   <ul>
      <li> List Item 1 </li>
      <li> List Item 2 </li>
   </ul>
  
   <ul>
      <li> List Item 3 </li>
      <li> List Item 4 </li>
   </ul>  
</div>

    来你把List Item 2取出来,如果你已经取出来或者是放弃了,来继续。

  解决办法1

办法很多,我们看一些比较方便的。首先是first-of-type。

ul:first-of-type > li:nth-child(2) {
   font-weight: bold;
}

    找到第一个ul标签,然后找到直接子标签li,然后找到第二个子节点。

  解决办法2

  另一个解决办法就是邻近选择器。

p + ul li:last-child {
   font-weight: bold;
}

    这种情况下,找到p下的直接ul标签,然后找到它的最后一个直接子标签。

  解决办法3

  我们可以随便玩耍这些选择器。来看看:

ul:first-of-type li:nth-last-child(1) {
   font-weight: bold;  
}

    先获取到页面上第一个ul标签,然后找到最后一个子标签。

  DEMO

  兼容性

IE9+

Firefox 3.5+

Chrome

Safari

Opera

结论

 如果你想向旧版本浏览器妥协,比如IE6,那你用这些新的选择器的时候还是得小心点。但别别让IE6阻止你去学这些新的技能。那你就对自己太残忍了。记得多查查兼容性列表,或者使用Dean Edward’s excellent IE9.js script 来让你的浏览器具有这些特性。

  第二个,使用向jQuery的时候,尽量使用原生的CSS3选择器。可能 活让你的代码跑的很快。这样选择器引擎就可以使用浏览器原生解析器,而不是选择器自己的。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

1

2026.03.13

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

39

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

140

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

47

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

90

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

102

2026.03.06

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

226

2026.03.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

505

2026.03.04

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

170

2026.03.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 42.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号