文章目录
复合选择器
定义:由两个或多个基础选择器,通过不同的方式组合而成。
作用:更准确、更高效的选择目标元素(标签)。
后代选择器
后代选择器:选中某元素的后代元素。
选择器写法:父选择器 子选择器 { CSS 属性},父子选择器之间用空格隔开。
<style>
.first li{
color: aqua;
}
.sconde li{
color: blue;
}
</style>
<body>
<ul class="first li">
<li>我是无序列表</li>
<li>我是无序列表</li>
<li>我是无序列表</li>
</ul>
<hr>
<ul class="sconde li">
<li>我是无序列表</li>
<li>我是无序列表</li>
<li>我是无序列表</li>
</ul>
<hr>
<ol>
<li>我是有序列表</li>
<li>我是有序列表</li>
<li>我是有序列表</li>
</ol>
</body>
如下图所示:
小技巧: 后代选择器执行代码的时候,先执行孩子,后执行父亲。 先找li 后找ul
我们找刘德华,先确定刘德华(li), 然后确定刘德华在淄博 ul 吃烧烤
子代选择器
子代选择器:选中某元素的子代元素(最近的子级)。
选择器写法:父选择器 > 子选择器 { CSS 属性},父子选择器之间用 > 隔开。
/* li 是 ol 的子代选择器 */
ol > li{
color: blueviolet;
font-size: 15px;
font-weight: 700;
}
ol li{
width: 100px;
height: 100px;
background-color: chartreuse;
}
<ol>
<li>我是有序列表</li>
<li>我是有序列表</li>
<li>我是有序列表</li>
</ol>
如下图所示:
并集选择器
并集选择器:选中多组标签设置相同的样式。
选择器写法:选择器1, 选择器2, …, 选择器N { CSS 属性},选择器之间用 , 隔开。
/* 并集选择器 */
div,
span,
p{
color: rosybrown;
}
<div>我是div</div>
<span>我是span</span>
<p>我是段落</p>
<strong>我是加粗</strong>
如下图所示:
交集选择器
交集选择器:选中同时满足多个条件的元素。
选择器写法:选择器1选择器2 { CSS 属性},选择器之间连写,没有任何符号。
<style>
/* 交集选择器 */
div.box{
color: pink;
}
</style>
<body>
<div class="box">我是第一个</div>
<div>我是第二个</div>
</body>
如下图所示:
注意:如果交集选择器中有标签选择器,标签选择器必须书写在最前面。
伪类选择器
伪类选择器:伪类表示元素状态,选中元素的某个状态设置样式。
鼠标悬停状态:选择器:hover { CSS 属性 }
<style>
a{
color: black;
text-decoration: none;
font-size: 20px;
}
a:hover{
color: orange;
text-decoration: underline;
}
</style>
<body>
<a href="#">百度一下</a>
</body>
鼠标悬停之前:
鼠标悬停之后:
超伪类选择器
提示:如果要给超链接设置以上四个状态,需要按 LVHA 的顺序书写。
经验:工作中,一个 a 标签选择器设置超链接的样式, hover状态特殊设置
<style>
a:link{
color: black;
text-decoration: none;
font-size: 20px;
}
a:visited{
color: red;
}
a:hover{
color: orange;
text-decoration: underline;
}
a:active{
color: green;
}
</style>
<body>
<a href="#">百度一下</a>
</body>
访问之前:
访问之后:
鼠标悬停:
点击时:
CSS特性
CSS特性:化简代码 / 定位问题,并解决问题
- 继承性
- 层叠性
- 优先级
继承性
继承性:子级默认继承父级的文字控制属性。
注意:如果标签有默认文字样式会继承失败。 例如:a 标签的颜色、标题的字体大小。
层叠性
特点:
- 相同的属性会覆盖:后面的 CSS 属性覆盖前面的 CSS 属性
- 不同的属性会叠加:不同的 CSS 属性都生效
<style>
/* 层叠性:相同的属性,会被后面的属性覆盖掉
不相同的属性,不会被后面的属性覆盖 */
div{
color: pink;
}
div{
font-size: 20px;
color: red;
}
</style>
<body>
<div>我是div</div>
</body>
如图所示:
注意:选择器类型相同则遵循层叠性,否则按选择器优先级判断。
开发者工具中的CSS样式:
优先级
优先级:也叫权重,当一个标签使用了多种选择器时,基于不同种类的选择器的匹配规则。
基础选择器
规则:选择器优先级高的样式生效。
公式:通配符选择器 < 标签选择器 < 类选择器 < id选择器 < 行内样式 < !important
(选中标签的范围越大,优先级越低)
复合选择器-叠加
叠加计算:如果是复合选择器,则需要权重叠加计算。
公式:(每一级之间不存在进位)
规则:
- 从左向右依次比较选个数,同一级个数多的优先级高,如果个数相同,则向后比较
- !important 权重最高
- 继承权重最低
选择器 | 权重 | 说明 |
---|---|---|
继承/ *通配符 | 0 | 没有权重 |
标签选择器 | 1 | 累加 |
类选择器/伪类选择器 | 10 | 累加 |
id选择器 | 100 | 累加 |
行内 | 1000 | |
!important | ∞ | |
提示:在调试工具里,上看层叠,下看继承。
继承的权重为0
<style>
/* li 的权重是1 , 比 div 的权重大, 所以可以修改 li 的样式 */
li{
font-size: 20px;
color: pink;
}
/* 继承的权重为0 , 所以无法修改 li 的样式 */
.box1{
font-size: 30px;
color: royalblue;
}
</style>
<body>
<div class="box1">
<li>我是li</li>
</div>
</body>
如图所示:
Emmet 写法
Emmet写法:代码的简写方式,输入缩写 VS Code 会自动生成对应的代码。
- HTML标签
- CSS:大多数简写方式为属性单词的首字母
背景属性
背景图
网页中,使用背景图实现装饰性的图片效果。
- 属性名:background-image(bgi)
- 属性值:url(背景图 URL)
<style>
.box{
width: 200px;
height: 200px;
background-color: greenyellow;
background-image: url(./imgs/1.png);
}
</style>
<body>
<div class="box"></div>
</body>
提示:背景图默认有平铺(复制)效果。
平铺方式
属性名:background-repeat(bgr)
背景图位置
属性名:background-position(bgp)
属性值:水平方向位置 垂直方向位置
- 关键字
- 坐标(数字 + px)
- 水平:正数向右;负数向左
- 垂直:正数向下;负数向上
<style>
/* 背景图片位置 */
background-position: center center;
/* 背景图片位置 坐标表示法,严格按照顺序,第一个数字是x,第二个数字是y */
background-position: 50px 20px;
</style>
<body>
<div class="box"></div>
</body>
提示:
- 关键字取值方式写法,可以颠倒取值顺序。
- 可以只写一个关键字,另一个方向默认为居中;数字只写一个值表示水平方向,垂直方向为居中。
背景图缩放
作用:设置背景图大小
属性名:background-size(bgz)
常用属性值:
- 关键字
- cover:等比例缩放背景图片以完全覆盖背景区,可能背景图片部分看不见
- contain:等比例缩放背景图片以完全装入背景区,可能背景区部分空白
- 百分比:根据盒子尺寸计算图片大小
- 数字 + 单位(例如:px)
提示:工作中,图片比例与盒子比例相同,使用 cover 或 contain 缩放背景图效果相同。
背景图固定
作用:背景不会随着元素的内容滚动。
属性名:background-attachment(bga)
属性值:fixed
<style>
body{
background-image: url(./imgs/wz.jpg);
background-repeat: no-repeat;
background-position: center ;
/* 背景图固定 */
background-attachment: fixed;
}
</style>
背景复合属性
属性值:背景色 背景图 背景图平铺方式 背景图位置/背景图缩放 背景图固定(空格隔开各个属性值,不区分顺序)
div {
width: 400px;
height: 400px;
background: pink url(./images/1.png) no-repeat right center/cover;
}
注意:背景图缩放一定要在背景图位置后面。
显示模式
显示模式:标签(元素)的显示方式。
作用:布局网页的时候,根据标签的显示模式选择合适的标签摆放内容。
块级元素
特点:
- 独占一行
- 宽度默认是父级的100%
- 添加宽高属性生效
<style>
/* 块级模式 */
.box1,
.box2{
width: 100px;
height: 100px;
background-color: pink;
}
</style>
<body>
<div class="box1">div1</div>
<div class="box2">
<p>123</p>
<p>123</p>
</div>
</body>
如下图所示:
行内元素
特点:
- 一行可以显示多个
- 设置宽高属性不生效
- 宽高尺寸由内容撑开
<style>
/* 行内元素 */
span{
/* 宽和高都不生效 */
width: 100px;
height: 100px;
background-color: rebeccapurple;
}
</style>
<body>
<span>abc</span>
<span>12345</span>
</body>
行内块元素
特点:
- 一行可以显示多个
- 设置宽高属性生效
- 宽高尺寸也可以由内容撑开
转换显示模式
属性:display
经验:
- 我们重点记住把行内元素比如链接转换为 块级或者行内块即可
- display: block 尽量写到样式的第一行
- 块级元素可以控制里面的行内元素或者行内块元素 左中右对齐 tac 控制
- 块级元素不能控制里面的块级元素对齐