0

0

CSS选择器笔记

php中文网

php中文网

发布时间:2016-10-15 10:32:03

|

1208人浏览过

|

来源于php中文网

原创

一、元素选择符

序号 选择器 含义
1. * 通用元素选择器,匹配任何元素
2. E 标签选择器,匹配所有使用E标签的元素
3. .info class选择器,匹配所有class属性中包含info的元素
4. #footer id选择器,匹配所有id属性等于footer的元素

1. *

* {
  margin: 0;
  padding: 0;
}

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

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

它会选中`#container`下的所有元素。

2. E

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

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

3. .info

.error {
  color: red;
}

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

4. #footer

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

在选择器中使用`#`可以用id来定位某个元素。

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

二、多元素的组合选择器

序号 选择器 含义
5. E,F 多元素选择器,同时匹配所有E元素或F元素,E和F之间用逗号分隔
6. E F 后代元素选择器,匹所有属于E元素后代的F元素,E和F之间用空格分隔
7. E > F 子元素选择器,匹配所有E元素的子元素F
8. E + F 相邻元素选择器,匹配所有紧随E元素之后的同级元素F
9. E~F 匹配任何在E元素之后的同级F元素

5. E,F

a,li { color: red; }

匹配所有的a元素和li元素

6. E F

li a {
  text-decoration: none;
}

只匹配li后面多有的a元素(包括孙子辈)

7. E > F

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

只匹配li后面多有的a元素(不包括孙子辈)`E F`和`E > F`的差别就是后面这个指挥选择它的直接子元素。看下面的例子:

 1 <div id="container">
 2 <ul>
 3     <li> List Itemli>
 4     <ul>
 5         <li> Child li>
 6     ul>
 7     <li> List Item li>
 8     <li> List Item li>
 9     <li> List Item li>
10 ul>
11 div>

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

8. E + F

ul + p {
   color: red;
}

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

9. E~F

ul ~ p {
  color: red;
}

`ul + p`选择器只会选择紧挨跟着指定元素的那些元素。而这个选择器,会选择跟在目标元素后面的所有匹配的元素。

三、关系选择器

序号 选择器 含义
10. E[att] 匹配所有具有att属性的E元素,不考虑它的值。(注意:E在此处可以省略,比如"[cheacked]"。以下同。)
11. E[att=val] 匹配所有att属性等于"val"的E元素
12. E[att~=val] 匹配所有att属性具有多个空格分隔的值、其中一个值等于"val"的E元素
13. E[att|=val] 匹配所有att属性且属性值为以val开头并用连接符"-"分隔的字符串的E元素。
14. E[att^="val"] 匹配所有att属性以"val"开头的元素
15. E[att$="val"] 匹配所有att属性以"val"结尾的元素
16. E[att*="val"] 匹配所有att属性包含"val"字符串的元素

10. E[att]

匹配所有具有att属性的E元素,不考虑它的值。

 1 <style>
 2 a[class]{color:#f00;}
 3 style>
 4 head>
 5 <body>
 6 <ul>
 7     <li><a href="?" class="external">外部链接a>li>
 8     <li><a href="?">内部链接a>li>
 9     <li><a href="?" class="external">外部链接a>li>
10     <li><a href="?">内部链接a>li>
11 ul>
12 body>

上面的这个例子中,只会选择有class属性的元素。那些没有此属性的将不会被这个代码修饰。

11. E[att=val]

匹配所有att属性等于"val"的E元素

a[class="external"]{color:#f00;}

上面这片代码将会把`class`属性值为`external`的标签设置为红色,而其他标签则不受影响。

12. E[att~=val]

匹配所有att属性具有多个空格分隔的值、其中一个值等于"val"的E元素

<style>
a[class~="external"]{color:#f00;}
style>
head>
<body>
<ul>
    <li><a href="?" class="external txt">外部链接a>li>
    <li><a href="?" class="txt">内部链接a>li>
    <li><a href="?" class="external txt">外部链接a>li>
    <li><a href="?" class="txt">内部链接a>li>
ul>
body>

这个`~`符号可以定位那些某属性值是空格分隔多值的标签(因此只有外部链接是红色字体)。

13. E[att|=val]

选择具有att属性且属性值为以val开头并用连接符"-"分隔的字符串的E元素。

 1 <style>
 2 li[class|="test3"]{color:#f00;}
 3 style>
 4 head>
 5 <body>
 6 <ul>
 7     <li class="test1-abc">列表项目1li>
 8     <li class="test2-abc">列表项目2li>
 9     <li class="test3-abc">列表项目3li>
10     <li class="test4-abc">列表项目4li>
11     <li class="test5-abc">列表项目5li>
12     <li class="test6-abc">列表项目6li>
13 ul>
14 body>

因此只有项目3为红色。

14. E[att^="val"]

选择具有att属性且属性值为以val开头的字符串的E元素。
 1 <body>
 2 <ul>
 3     <li class="abc">列表项目1li>
 4     <li class="acb">列表项目2li>
 5     <li class="bac">列表项目3li>
 6     <li class="bca">列表项目4li>
 7     <li class="cab">列表项目5li>
 8     <li class="cba">列表项目6li>
 9 ul>
10 body>
li[class^="a"]{color:#f00;}

选择具有class属性且属性值为以a开头的字符串的E元素(因此只有项目1、2为红色)。

15. E[att$="val"]

匹配所有att属性以"val"结尾的元素

li[class$="a"]{color:#f00;}

选择具有class属性且属性值为以a结尾的字符串的E元素(项目4、6为红色)。

16. E[att*="val"]

匹配所有att属性包含"val"字符串的元素

li[class*="a"]{color:#f00;}

因为class的属性中都含有字母a所以结果均为红色。

 四、伪类选择器

17. E:link 匹配所有未被点击的链接
18. E:visited 匹配所有已被点击的链接
19. E:hover 匹配鼠标悬停其上的E元素
20. E:active 匹配鼠标已经其上按下、还没有释放的E元素
21. E:first-child 匹配父元素的第一个子元素E
22. E:last-child 匹配父元素的最后一个子元素E
23. E:only-child 匹配父元素仅有的一个子元素E
24. E:nth-child(n) 匹配父元素的第n个子元素E
25. E:nth-last-child(n) 匹配父元素的倒数第n个子元素E
26. E:first-of-type 匹配同类型中的第一个同级兄弟元素E
27. E:last-of-type 匹配同类型中的最后一个同级兄弟元素E
28. E:only-of-type 匹配同类型中的唯一的一个同级兄弟元素E
29. E:nth-of-type(n) 匹配同类型中的第n个同级兄弟元素E
30. E:nth-last-of-type(n) 匹配同类型中的倒数第n个同级兄弟元素E

17. E:link

设置超链接a在未被访问前的样式。

1 <ul>
2     <li><a href="?" class="external">外部链接a>li>
3     <li><a href="?">内部链接a>li>
4     <li><a href="?" class="external">外部链接a>li>
5     <li><a href="?">内部链接a>li>
6 ul>
a:link{color:#03c;}
.external:link{color:#f00;}

运行结果:外部链接为红色;内部链接为蓝色

18. E:visited

设置超链接a在其链接地址已被访问过时的样式。

19. E:hover

设置元素在其鼠标悬停时的样式。

带标记的日期选择器
带标记的日期选择器

带标记的日期选择器

下载

20. E:active

设置元素在被用户激活(在鼠标点击与释放之间发生的事件)时的样式。

21. E:first-child

匹配父元素的第一个子元素E。

1 <body>
2 <ul>
3     <li>test1li>
4     <li>test2li>
5     <li>test3li>
6     <li>test4li>
7     <li>test5li>
8 ul>
9 body>
li:first-child{color:#f00;}

结果只有列表第一条信息test1为红色

22. E:last-child

匹配父元素的最后一个子元素E。

li:last-child{color:#f00;}

结果只有列表最后一条信息test5为红色

23. E:only-child

匹配父元素仅有的一个子元素E。

1 <ul>
2     <li>test1li>
3 ul>
4 <ul>
5    <li>test2li>
6     <li>test3li>
7     <li>test4li>
8 ul>
li:only-child{color:#f00;}

结果只有列表test1为红色

24. E:nth-child(n)

匹配父元素的第n个子元素E。

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

结果只有列表test3为红色

25. E:nth-last-child(n)

匹配父元素的倒数第n个子元素E。

li:nth-last-child(3){color:#f00;}

结果只有列表test3为红色

26. E:first-of-type

匹配同类型中的第一个同级兄弟元素E。

1 <div class="test">
2     <div><b>我是一个div元素b>div>
3     <p>这是段落1p>
4     <p>这是段落2p>
5     <p>这是段落3p>
6     <p>这是段落4p>
7     <p>这是段落5p>
8 div>
p:first-of-type{color:#f00;}

结果只有这是段落1为红色。

27. E:last-of-type

匹配同类型中的最后一个同级兄弟元素E。

p:last-of-type{color:#f00;}

结果只有这是段落5为红色。

28. E:only-of-type

匹配同类型中的唯一的一个同级兄弟元素E。 

b:only-of-type{color:f00;}

结果只有我是一个div元素为红色。

29. E:nth-of-type(n)

匹配同类型中的第n个同级兄弟元素E,n 可以代表数字也可以代表字母。 

p:nth-of-type(2){color:#f00;}

结果只有这是段落2为红色。

n为odd时表示奇数;n为even表示偶数;

p:nth-of-type(odd){color:#f00;}

结果:段落1、3、5显示为红色。

p:nth-of-type(even){color:#f00;}

结果:段落2、4显示为红色。

30. E:nth-last-of-type(n)

匹配同类型中的倒数第n个同级兄弟元素E,n 可以代表数字也可以代表字母。。 

p:nth-last-of-type(2){color:#f00;}

结果:段落4显示为红色。

n为odd时表示奇数;n为even表示偶数;

p:nth-last-of-type(odd){color:#f00;}

结果:段落1、3、5显示为红色。

p:nth-last-of-type(even){color:#f00;}

结果:段落2、4显示为红色。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

1

2026.01.31

go语言 math包
go语言 math包

本专题整合了go语言math包相关内容,阅读专题下面的文章了解更多详细内容。

1

2026.01.31

go语言输入函数
go语言输入函数

本专题整合了go语言输入相关教程内容,阅读专题下面的文章了解更多详细内容。

1

2026.01.31

golang 循环遍历
golang 循环遍历

本专题整合了golang循环遍历相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.31

Golang人工智能合集
Golang人工智能合集

本专题整合了Golang人工智能相关内容,阅读专题下面的文章了解更多详细内容。

1

2026.01.31

2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

73

2026.01.31

高干文在线阅读网站大全
高干文在线阅读网站大全

汇集热门1v1高干文免费阅读资源,涵盖都市言情、京味大院、军旅高干等经典题材,情节紧凑、人物鲜明。阅读专题下面的文章了解更多详细内容。

72

2026.01.31

无需付费的漫画app大全
无需付费的漫画app大全

想找真正免费又无套路的漫画App?本合集精选多款永久免费、资源丰富、无广告干扰的优质漫画应用,涵盖国漫、日漫、韩漫及经典老番,满足各类阅读需求。阅读专题下面的文章了解更多详细内容。

67

2026.01.31

漫画免费在线观看地址大全
漫画免费在线观看地址大全

想找免费又资源丰富的漫画网站?本合集精选2025-2026年热门平台,涵盖国漫、日漫、韩漫等多类型作品,支持高清流畅阅读与离线缓存。阅读专题下面的文章了解更多详细内容。

19

2026.01.31

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
兄弟连高洛峰CSS3视频教程
兄弟连高洛峰CSS3视频教程

共20课时 | 4万人学习

Css3入门基础视频教程
Css3入门基础视频教程

共33课时 | 6.6万人学习

黑马云课堂jQuery基础视频教程
黑马云课堂jQuery基础视频教程

共46课时 | 10.1万人学习

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

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