文章目录
选择器的作用
CSS选择器干啥的? 选择标签用的! 就是把我们想要的标签选择出来,找到特定的HTML页面元素。
h3 {
color: red;
}
/*
css 就是 分两件事, 选对人, 做对事。
这段代码就是2件事, 把 h3选出来,然后 把它变成了 红色。 以后我们都这么干。
*/
选择器的分类
一 基础选择器(简单)
1 通配符选择器
-
概念: 通配符选择器用
*
号表示, * 就是选择所有的标签。他是所有选择器中作用范围最广的,能匹配页面中所有的元素。 -
其基本语法格式如下:
* { 属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }
例如下面的代码,使用通配符选择器定义CSS样式,清除所有HTML标记的默认边距。
* {
margin: 0; /* 定义外边距*/
padding: 0; /* 定义内边距*/
}
- 注意: 会匹配页面所有的元素,降低页面响应速度,不建议随便使用
2 标签选择器
- 概念: 标签选择器(元素选择器)是指用HTML标签名称作为选择器,按标签名称分类,为页面中某一类标签指定统一的CSS样式。
- 语法:
标签名{属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }
示例:
div {
color: red;
}
/*将所有div的字体改为红色*/
- 作用:
标签选择器 可以把某一类标签全部选择出来 比如所有的div标签 和 所有的 span标签 - 优点:
是能快速为页面中同类型的标签统一样式 - 缺点:
不能设计差异化样式。
3 id选择器
id选择器使用#
进行标识,后面紧跟id名
-
其基本语法格式如下:
-
id选择器
#id名 {属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }
-
标签使用
<p id="id名"></p>
-
-
元素的id值是唯一的,只能对应于文档中某一个具体的元素。
-
用法基本和类选择器相同。
4 类选择器
类选择器使用“.”(英文点号)进行标识,后面紧跟类名.
- 语法:
.类名 {
属性1:属性值1;
属性2:属性值2;
属性3:属性值3;
}
- 标签
<p class='类名'></p>
-
优点:可以为元素对象定义单独或相同的样式。 可以选择一个或者多个标签
-
注意:
- 类选择器使用“.”(英文点号)进行标识,后面紧跟类名(自定义,我们自己命名的)
- 长名称或词组可以使用中横线来为选择器命名。
- 不要纯数字、中文等命名, 尽量使用英文字母来表示。
5 id选择器和类选择器的区别
W3C标准规定,在同一个页面内,不允许有相同名字的id对象出现,但是允许相同名字的class。
- 类选择器(class) 好比人的名字, 是可以多次重复使用的, 比如张三,李四,王五
- id选择器 好比人的身份证号码, 全中国是唯一的, 不得重复。 只能使用一次。
id选择器和类选择器最大的不同在于使用次数上。
6 基础选择器总结
选择器 | 作用 | 缺点 | 使用情况 | 用法 |
---|---|---|---|---|
标签选择器 | 可以选出所有相同的标签,比如p | 不能差异化选择 | 较多 | p { color:red;} |
类选择器 | 可以选出1个或者多个标签 | 可以根据需求选择 | 非常多 | .nav { color: red; } |
id选择器 | 一次只能选择器1个标签 | 只能使用一次 | 不推荐使用 | #nav {color: red;} |
通配符选择器 | 选择所有的标签 | 选择的太多,有部分不需要 | 不推荐使用 | * {color: red;} |
二 复合选择器(有点重要哦)
1.后代选择器
- 概念: 后代选择器又称为包含选择器
- 作用: 用来选择元素或元素组的子孙后代
- 其写法就是把外层标签写在前面,内层标签写在后面,中间用空格分隔,先写长辈,在写晚辈。
- 注:当标签发生嵌套时,内层标签就成为外层标签的后代。
父级 子级{属性:属性值;属性:属性值;}
div .highlight {background-color: red;}
示例:
<style>
div {
width: 200px;
height: 200px;
background-color: pink;
}
/* 高亮被选择的元素 */
/*这是后代选择器*/
div .highlight {
background-color: red;
}
</style>
<div></div>
<div>
<p class="highlight">我会高亮</p>
</div>
<p class="highlight">我不会高亮</p>
<div>
<span>
<p class="highlight">我的父级标签是span,我的爷爷才是div,我会高亮嘛?</p>
</span>
</div>
效果图:后代选择器选的是类选择器highlight, 所以只要没有类选择器的highlight的都不会高亮,但又因它是后代选择器,所以必须是嵌套在div元素下,同时有类highlight的元素才会高亮。
注:只要在div里面就行,可以是div的“儿子”,也可以是div的“孙子”,“重孙”。
2.子元素选择器
前言:子元素选择器类似于后代选择器,只是缩小了范围,只能是儿子(记忆时可一起记忆后代选择器和子元素选择器)!!!
- 作用: 子元素选择器只能选择作为某元素**子元素(亲儿子)**的元素。
- 其写法就是把父级标签写在前面,子级标签写在后面,中间跟一个
>
进行连接 - 语法:
div .highlight {background-color: red;}
示例:
div {
width: 200px;
height: 200px;
background-color: pink;
}
/* 高亮被选择的元素 */
/*这是子元素选择器**/
div>.highlight {
background-color: red;
}
<body>
<div></div>
<div>
<p class="highlight">我会高亮</p>
</div>
<p class="highlight">我不会高亮</p>
<div>
<span>
<p class="highlight">我的父级标签是span,我的爷爷才是div,我会高亮嘛?</p>
</span>
</div>
</body>
效果图:
3.交集选择器
- 条件:交集选择器由两个选择器构成,找到的标签必须满足:既有选择器1,也有选择器2。
- 语法:
div.highlight { background-color: red;}
- 其中第一个为标签选择器,第二个为class选择器,两个选择器之间不能有空格,如div.highlight。
示例:
div {
width: 200px;
height: 200px;
background-color: pink;
}
/* 高亮被选择的元素 */
div.highlight {
background-color: red;
}
<div>我不会高亮</div>
<span class="highlight">我也不会高亮</span>
<div class="highlight">哈哈哈,只有我才会高亮</div>
效果图:
4.并集选择器
- 应用:如果某些选择器定义的样式相同,就可以利用并集选择器,可以让代码更简洁。并集选择器(CSS选择器分组)是各个选择器通过
,
连接而成的,通常用于集体声明。 - 语法:
#highlight,
.highlight,
div {
background-color: red;
}
-
任何形式的选择器(包括标签选择器、class类选择器id选择器等),都可以作为并集选择器的一部分。
-
记忆技巧:并集选择器通常用于集体声明 ,逗号隔开的,所有选择器都会执行后面样式,逗号可以理解为 和的意思。
示例:
#highlight,
.highlight,
div {
background-color: red;
}
<div>我高亮了</div>
<h3 id="highlight">我也高亮了</h3>
<p class="highlight">哈哈哈哈,我们都高亮了</p>
效果图:
5.复合选择器总结
选择器 | 作用 | 特征 | 使用情况 | 隔开符号及用法 |
---|---|---|---|---|
后代选择器 | 用来选择元素后代 | 是选择所有的子孙后代 | 较多 | 符号是空格 .nav a |
子代选择器 | 选择 最近一级元素 | 只选亲儿子 | 较少 | 符号是**>** .nav>p |
交集选择器 | 选择两个标签交集的部分 | 既是 又是 | 较少 | 没有符号 p.one |
并集选择器 | 选择某些相同样式的选择器 | 可以用于集体声明 | 较多 | 符号是逗号 .nav, .header |
三 有点高级的选择器(哈哈哈)
1.属性选择器
-
什么是
CSS3
- 在
CSS2
的基础上拓展、新增的样式
- 在
-
CSS3
发展现状- 移动端支持优于
PC
端 CSS3
目前还草案,在不断改进中CSS3
相对H5
,应用非常广泛
- 移动端支持优于
-
属性选择器列表
示例:
/* 属性选择器使用方法 */
/* 选择的是:既是button 又有 disabled 这个属性的元素 */
/* 属性选择器的权重是 10 */
/* 1.直接写属性 */
button[disabled] {
cursor: default;
}
button {
cursor: pointer;
}
/* 2. 属性等于值 */
input[type="search"] {
color: pink;
}
/* 3. 以某个值开头的 属性值 */
div[class^="icon"] {
color: red;
}
/* 4. 以某个值结尾的 */
div[class$="green"] {
color: green;
}
/* 5. 可以在任意位置的 */
div[class*="blue"] {
color: blue;
}
<!-- disabled 是禁用我们的按钮 -->
<button>按钮1</button>
<button disabled="disabled">按钮2</button>
<input type="text" name="" id="" value="文本框">
<input type="search" name="" id="" value="搜索框">
<div class="icon1">icon1</div>
<div class="icon2">icon2</div>
<div class="1green">1green</div>
<div class="2green">2green</div>
<div class="1blue">1blue</div>
<div class="blue1">blue1</div>
<div class="1blue1">1blue1</div>
效果图:
2.伪类选择器
伪类选择器和类选择器有些相似,毕竟名字都这么像。请往下看呢。为了和我们刚才学的类选择器相区别,类选择器是一个点 比如 .demo {}。而我们的伪类 用 2个点 就是 冒号 比如 :link{}
1)链接伪类选择器
作用:用于向某些选择器添加特殊的效果。比如给链接添加特殊效果。
- a:link /* 未访问的链接 */
- a:visited /* 已访问的链接 */
- a:hover /* 鼠标移动到链接上 */
- a:active /* 选定的链接 */
注意:
- 写的时候,他们的顺序尽量不要颠倒 按照 lvha 的顺序。否则可能引起错误。
- 记忆法
- love hate 爱上了讨厌
- **lv **包包 非常 hao
- 因为叫链接伪类,所以都是利用交集选择器(和类是不是有点点联系了呢) a:link a:hover
- 因为a链接浏览器具有默认样式,所以我们实际工作中都需要给链接单独指定样式。
- 实际工作开发中,我们很少写全四个状态,一般我们写法如下:
a { /* a是标签选择器 所有的链接 */
font-weight: 700;
font-size: 16px;
color: gray;
}
a:hover { /* :hover 是链接伪类选择器 鼠标经过 */
color: red; /* 鼠标经过的时候,由原来的 灰色 变成了红色 */
}
咳咳:我不会做动图,也不会弄视频,效果图就不上了哈哈哈哈,忘体谅,嘻嘻。
2)结构伪类选择器
- 属性列表
- 代码演示
注意!!!!表格前三个都是匹配的父元素中的子的元素!!!!!
但是不要这么理解:认为 p:first-child 之类的选择器会选择 p 元素的第一个子元素。
正确理解:p:first-child之类的选择器会选择作为某个元素中的第一个元素的p元素(用白话来讲就是,改选择器选择的元素既要是某个元素的第一个元素,又要是p元素,两个条件缺一不可),因为这种选择器选择范围比较大,所以我们常常会配合后代选择器一起使用,如 ul li:first-child
ul li:first-child {
background-color: red;
}
ul li:last-child {
background-color: blue;
}
ul li:nth-child(3) {
background-color: pink;
}
<ul>
<li>1</li>
<li>2</li>
<li>3</li>
<li>4</li>
<li>5</li>
</ul>
效果图:
(1)nth-child
参数详解
-
nth-child 详解
-
注意:本质上就是选中第几个子元素
-
n 可以是数字、关键字、公式
-
n 如果是数字,就是选中第几个
-
常见的关键字有
even
偶数、odd
奇数 -
常见的公式如下(如果 n 是公式,则从 0 开始计算)
-
但是第 0 个元素或者超出了元素的个数会被忽略
-
-
代码演示
<style> /* 偶数 */ ul li:nth-child(even) { background-color: aquamarine; } /* 奇数 */ ul li:nth-child(odd) { background-color: blueviolet; } /*n 是公式,从 0 开始计算 */ ul li:nth-child(n) { background-color: blue; } /* 偶数 */ ul li:nth-child(2n) { background-color: lightskyblue; } /* 奇数 */ ul li:nth-child(2n + 1) { background-color: lightsalmon; } /* 选择第 0 5 10 15, 应该怎么选 */ ul li:nth-child(5n) { background-color: orangered; } /* n + 5 就是从第5个开始往后选择 */ ul li:nth-child(n + 5) { background-color: peru; } /* -n + 5 前五个 */ ul li:nth-child(-n + 5) { background-color: tan; } </style>
效果图太多了:我就演示几个
<!-- html代码都是这 -->
<li>1</li>
<li>2</li>
<li>3</li>
<li>4</li>
<li>5</li>
<li>6</li>
<li>7</li>
<li>8</li>
示例一:
ul li:nth-child(n) {
background-color: blue;
}
示例二
ul li:nth-child(2n + 1) {
background-color: pink;
}
示例三:
ul li:nth-child(-n + 5) {
background-color: blue;
}
nth-child
和 nt-of-type
的区别
-
区别
1
nth-child
选择父元素里面的第几个子元素,不管是什么类型
2nth-of-type
选择指定类型的元素.
3. 伪元素选择器
-
伪元素选择器
-
伪元素选择器注意事项
before
和after
必须有content
属性before
在内容前面,after 在内容后面before
和after
创建的是一个元素,但是属于行内元素- 创建出来的元素在
Dom
中查找不到,所以称为伪元素 - 伪元素和标签选择器一样,权重为 1
-
代码演示
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
div {
width: 200px;
height: 100px;
border: 1px solid #000000;
}
div::after,
div::before {
width: 50px;
height: 50px;
text-align: center;
display: inline-block;
}
div::after {
content: '德';
background-color: skyblue;
}
div::before {
content: '道';
background-color: pink;
}
</style>
</head>
<body>
<div>你好</div>
</body>
</html>
效果图: