目录
创作不易多多支持😶🌫️😘
Emmet语法前身是Zen coding , 它使用缩写, 来提高CSS / html的编写速度, VSCode中已经集成该语法..
CSS基本采用间歇性时即可
保存的时候自动格式化
下次保存文件后自动对齐
在CSS中, 可以根据选择器的类型, 把选择器分为基础选择器和符合选择器, 复合选择器是建立在基础选择器之上的 对基本选择器进行组合形成的.
后代选择器又称为包含选择器, 可以选择父元素里面的子元素, 其洗发就是把外层标签写在前面, 内层标签写在后面, 中间用空格分割, 当标签发生嵌套是, 内层标签, 就称为外层标签的后代.
例如:
- <ul>
- <li>嘿嘿嘿li>
- <li>嘿嘿嘿li>
- <li>嘿嘿嘿li>
- ul>
- <ol>
- <li>哈哈哈li>
- <li>哈哈哈li>
- <li>哈哈哈li>
- ol>
现在有两个列表标签, 我们现在有需求 : 需要将ol中的li的属性改为color: red, 就可以使用后代选择器:
- <style>
- ol li {
- color: red;
- }
- style>
语法规范
注意:
但是也许我们会遇到这种情况:
- <ol>
- <li>哈哈哈li>
- <li>哈哈哈li>
- <li>哈哈哈li>
- ol>
- <ol>
- <li>哈哈哈li>
- <li>哈哈哈li>
- <li>哈哈哈li>
- ol>
也许会存在两个完全相同的标签, 他们的子标签也想同, 但是我想要将下面这个标签里面的子标签设置样式, 这个时候还可以使用上面的方法吗?
答案是当然不行的, 这样子也会把上面那个标签的子标签给设置样式了:
于是, 为了区分第一个ol和第二个ol, 我就就需要给第二个ol设置一个类, 然后使用后代选择器的方式来选择第二个ol:
- <style>
- .test li {
- color: red;
- }
- style>
-
- <ol>
- <li>哈哈哈li>
- <li>哈哈哈li>
- <li>哈哈哈li>
- ol>
- <ol class="test">
- <li>哈哈哈li>
- <li>哈哈哈li>
- <li>哈哈哈li>
- ol>
另外一个例子:
- <style>
- div div {
- color: red;
- }
- style>
-
- <div>
- <p>
- <div>
- <p>
- <div>
- hahahaha
- div>
- p>
- div>
- p>
- <div>
- hahahha
- div>
- div>
子选择器只能 选择作为某元素的最近一级子元素, 简单理解就是选亲儿子元素
举个例子:
- <style>
- div>a {
- color: red;
- }
- style>
- <div>
- <a href="#">我是儿子a>
- <p>
- <a href="#">我是孙子a>
- p>
- div>
解释: 子类选择器只会选择直属的亲儿子, 不会选择重孙标签
需要注意的是:
- .nav ul li a {
- color: red;
- }
-
- <style>
- .hot>a {
- color: red;
- }
- style>
并集选择器可以选择多组标签, 同时给他们定义相同的样式, 通常用于集体声明.
并集选择器是各选择器通过英文逗号 , 连接而成, 任何形式的选择器都可以作为并集选择器的一部分.
需要注意的是:
有下面这个例子:
- <div>熊大div>
- <p>熊二p>
- <span>光头强span>
- <ul class="pig">
- <li>小猪佩奇li>
- <li>猪爸爸li>
- <li>猪妈妈li>
- ul>
现在我有两个要求:
第一个要求>>>
我们直接使用并集选择器, 将两个div和p标签一起选择
- <style>
- div,
- p {
- color: pink;
- }
- style>
第二个要求>>>
- <style>
- div,
- p,
- ul li {
- color: pink;
- }
- style>
伪类选择器用于向某些选择器添加特殊效果, 比如给链接添加特殊效果, 或者选择第一个, 第n个元素, 伪类选择器书写最大的特点就是使用 冒号(:) 表示, 比如 :hover, : first-child
对于一个链接来说, 也就是一个a标签. 如下:
<a href="#">这是一个链接a>
我们使用鼠标按下但是不弹开的时候会显示一个种红色:
但是如果我们要更改这种样式, 我们就必须使用到我们的链接伪类选择器, 设置如下:
一个案例:
- a:link {
- color: black;
- text-decoration: none;
- }
-
- a:visited {
- color: gray;
- }
-
- a:hover {
- color: green
- }
-
- a:active {
- color: blueviolet;
- }
- style>
- <a href="https://www.sogou.com/" target="_blank">这是一个链接a>
焦点是光标, 一般情况下, 类表单元素才可以获取, 因此这个选择器也主要针对于表单元素来说.
下面是其语法格式:
例如这里有三个表单, 我点击第三个表单, 那么焦点就会到第三个表单身上()
了解CSS的元素显示模式, 可以让我们更好的进行页面布局
作用: 网页的标签非常多, 在不同的地方会用到不同类型的标签, 了解他们的特点可以更好的布局我们的页面
元素显示模式, 总体来说, 就是元素(标签) 以上面方式进行显示, 比如div标签自己独占一行, span标签一行可以放多个
HTML元素分为两类:
常见的块级元素有h1 ~ h6, p. div, ul, ol. li等, 其中div标签是典型的块级元素
块级元素的特点:
<div>比较霸道自己独占一行div> 瑟瑟发抖
- <div>比较霸道自己独占一行div> 瑟瑟发抖
- <style>
- div {
- width: 200px;
- height: 200px;
- background-color: pink;
- }
- style>
注意:
常见的行内元素, 如a, strong, em,i, del, ins, span等, 其中span是最典型的行内元素, 其他的地方也将行内元素称为内联元素.
特点, 一行可以放多个行内元素:
<i>hello worldi> <strong>hahahhastrong><i>hello worldi> <strong>hahahhastrong>
行内元素的特点:
在行内元素中有几个特殊的标签>> img, input, td, 他们都具有块级元素和行内元素的特点, 有些资料称他们为行内块元素
行内块元素的特点:
元素模式 | 元素排列 | 设置样式 | 默认宽度 | 包含 |
块级元素 | 一行只能放一个块级元素 | 可以设置宽度和高度 | 容器的100% | 容器级可以包含任何标签 |
行内元素 | 一行可以放多个行内元素 | 不可以直接设置宽度和高度 | 它本身内容的宽度 | 容纳文本或其他行内元素 |
行内块元素 | 一行可以放多个行内块元素 | 可以设置宽度和高度 | 它本身内容的宽度 | |
下面的手机 电话卡这个栏目为一个a 标签, 但是现在我们需要将其设置宽度,让他能有下图显示的这么大, 这个时候我们就需要用到元素显示模式的切换.
特殊情况下, 我们需要元素显示模式的切换, 简单理解, 就是一个模式的元素需要另外一种模式的特性, 就例如我们上面这个例子, 需要增加连接a的触发范围.
一个例子, 我们对a设置宽度高度和背景颜色如下:
- <a href="#">hahahhaa>
- <style>
- a {
- height: 100px;
- width: 100px;
- background-color: orange;
- }
- style>
对a的高宽设置是不管用的, 没有任何效果.
因为a是行内元素, 这个时候我们就需要将其转化为块级元素,
设置属性. display: block;
- <a href="#">hahahhaa>
- <style>
- a {
- height: 100px;
- width: 100px;
- background-color: orange;
-
- /* 将a 转换为块级元素 */
- display: block;
- }
- style>
下面有两个块级元素div, 如下:
- <div>我是块级元素div>
- <div>我是块级元素div>
- <style>
- div {
- width: 300px;
- height: 100px;
- background-color: pink;
- }
- style>
效果图 如下:
如何将其设置为行内元素? 使用属性 display: inline;
- <div>我是块级元素div>
- <div>我是块级元素div>
- <style>
- div {
- width: 300px;
- height: 100px;
- background-color: pink;
- display: inline;
- }
- style>
设置属性 display: inline-block;
小米官网的侧边栏如下:
我们要做的简洁版如下:
我们在写这个的时候, 先不要着急, 不要上来就直接写代码, 应该是先分析一下.
案例核心思路:
- <div>
- <a href="#">手机电话卡a>
- <a href="#">电视盒子a>
- <a href="#">笔记本平板a>
- <a href="#">出行穿戴a>
- <a href="#">智能路由器a>
- <a href="#">健康儿童a>
- <a href="#">耳机音响a>
- div>
-
-
- <style>
- div {
- background-color: #535758;
- width: 280px;
- height: 350px;
- }
-
- a {
- text-decoration: none;
- display: block;
- color: white;
- height: 50px;
- text-indent: 2em;
- line-height: 50px;
- }
-
- a:hover {
- background-color: #FF6F00;
- }
- style>
(这里设置line-height 和 height 的值相同, 来实现垂直居中)
CSS中没有给我们提供文字垂直居中的代码, 但是我们这里可以有一个小技巧来实现.
小tip :
让文字的行高等于盒子的高度, 就可以让文字在当前盒子内垂直居中.
例如:
- <div>hellodiv>
- <style>
- div {
- background-color: gray;
- color: white;
- width: 200px;
- height: 200px;
- line-height: 200px;
- }
- style>
原理:
行高由上间隙和下间隙, 还有文字本身的高度组成.
这里假如盒子高度为40, 然后设置行高为40, 那么当这个文字插入到盒子之后
由于上间隙和下间隙是看不到的, 是透明的, 这就会显示文字到垂直居中了.
通过CSS背景属性, 可以给页面元素添加背景样式.
背景属性可以设置背景颜色, 背景图片, 背景平铺, 背景图片位置, 背景图像固定等.
设置CSS属性: background-color
语法如下:
一般情况下, 元素背景颜色默认值是transparent(透明), 我们也可以手动指定背景颜色为透明色.
我们现在设置一个div标签属性如下:
- <div>div>
- <style>
- div {
- width: 200px;
- height: 200px;
- border: 2px;
- border-style: dashed;
- }
- style>
可以看到这个div标签的背景是透明的, 也就是相当于在这个div属性中设置了:
background-color: transparent;
如果要将此div标签的背景颜色改为红色, 那就设置background-color属性为red即可:
- <div>div>
- <style>
- div {
- width: 200px;
- height: 200px;
- border: 2px;
- border-style: dashed;
- background-color: red;
- }
- style>
background-image 属性描述了元素的背景图像, 实际开发常见于logo 或者一些装饰性的小图片, 或者是超大的背景图片, 有点事便于控制位置, 精灵图也是一种运用场景, 例如:
background=image 的默认值为none, 也就是没有背景图片, 他可以传入一个url来设置图片.
例如, 我们设置一张背景图片
- <div>div>
- <style>
- div {
- width: 1024px;
- height: 1536px;
- border: 2px;
- border-style: dashed;
- background-image: url(https://img2.baidu.com/it/u=3357715627,3311806369&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=750);
- }
- style>
我们位置荣耀的一个logo是图中那个小红框那么大, 但是我们的盒子有外边最大的红框那么大. 于是就吧我们背景图片重复复制了几份.
这种重复的情况就是称为背景平铺, 如果需要在HTML页面上对背景进行平铺, 那么就需要使用欧冠background-repeat属性来设置:
- <div>div>
- <style>
- div {
- width: 500px;
- height: 500px;
- border: 2px;
- border-style: dashed;
- background-color: red;
- background-image: url(https://img0.baidu.com/it/u=1271524887,2752212953&fm=253&fmt=auto?w=130&h=170);
-
- }
- style>
默认情况下, 背景图片是平铺展示的, 也就是默认设置了:
background-repeat: repeat;
如果设置不平铺, 也就是:
background-repeat: no-repeat;
代码如下:
- <div>div>
- <style>
- div {
- width: 500px;
- height: 500px;
- border: 2px;
- border-style: dashed;
- background-color: red;
- background-image: url(https://img0.baidu.com/it/u=1271524887,2752212953&fm=253&fmt=auto?w=130&h=170);
- background-repeat: no-repeat;
- }
- style>
设置x方向平铺, 选择属性:
background-repeat: repeat-x;
设置y方向的平铺. 选择属性:
background-repeat: repeat-y;
背景图片会压着我们的背景颜色
利用background-position 属性可以改变图片在背景中的位置
如果指定的两个值都是方位名词, 那么两个值的前后顺序无关, 比如left top和top left 效果是一样的.
例如:
一个案例如下;
- <div>div>
- <style>
- div {
- width: 500px;
- height: 500px;
- border: 2px;
- border-style: dashed;
- background-color: red;
- background-image: url(https://img0.baidu.com/it/u=1271524887,2752212953&fm=253&fmt=auto?w=130&h=170);
- background-repeat: no-repeat;
- background-position: right bottom;
- }
- style>
注意: 如果只指定了一个方位名词, 另外一个省略, 则第二个默认居中对齐
还是使用background-position参数来设置, 只不过这个参数不是left right top和bottom, 而是准确的像素值, 例如 我们想设置一个背景图片距离左侧20px, 距离上侧30ox, 就可以设置如下:
- <div>div>
- <style>
- div {
- width: 500px;
- height: 500px;
- border: 2px;
- border-style: dashed;
- background-color: red;
- background-image: url(https://img0.baidu.com/it/u=1271524887,2752212953&fm=253&fmt=auto?w=130&h=170);
- background-repeat: no-repeat;
- background-position: 20px 30px;
- }
- style>
注意: 如果这里只写一个, 例如 :
background-position: 30px;
那么这个30px就一定指的是x轴的方向, 另外的y轴的默认是center的, 也就是相当于如下设置:
background-position: 30px center;
我们即可以使用left right等方位词, 也可以使用精确的像素值, 例如 30px等等, 但是除了这两种还有一种混合使用的位置, 也就是将这两种位置表达的方式结合起来的方法, 但是需要注意的是, 这种混合位置的表示方法需要注意方位的顺序, 例如, 第一个参数一定是x轴, 第二个参数一定是y轴.
background-attachment 属性设置背景图片是否固定或者随着叶念的其余部分滚动.
- <div class="test2">
-
- div>
- .test2 {
- width: 200px;
- height: 200px;
- background: rgba(0, 0, 0, 0.3);
- }
半透明背景色, 使用background: argb选项来设置, 案例如上图显示.
其中最后前三个参数为rgb色彩的值, 最后一个参数是alpha透明度, 取值范围在0~1之间
越接近于1, 越不透明
css有是哪个非常重要的特性: 层叠性, 继承性, 优先级
相同的选择器设置相同的样式, 此时的样式就会覆盖另外一个冲突的样式, 层叠性主要解决样式冲突的问题.
例如现在有一个div, 但是有两个选择器选择了这个div :
- <div>
- 哈哈你好啊
- div>
-
- <style>
- div {
- color: blue;
- }
-
- div {
- color: aqua;
- }
- style>
结果是哪个呢?? :
结果是aqua
层叠性原则:
CSS子标签可以继承父标签的样式, 例如文本颜色和字号, 简单理解就是: 子承父业
现在有一个例子如下:
- <div>
- <p>hello worldp>
- div>
-
- <style>
- div {
- color: red;
- }
- style>
子元素可以继承父元素的行高:
- <style>
- body {
- line-height: 30px;
- }
- style>
- <div> 这是一个div标签div>
- <p>这是一个p标签p>
行高可以跟单位, 也可以不跟单位
当同一个元素指定多个选择器, 就会有优先级的产生
优先级注意点:
需要注意的是: a链接默认指定了一个样式>>> 蓝色的有下划线
如果是符合选择器, 则会有权重叠加, 需要计算权重