CSS学习笔记
CSS
-层叠样式表
-网页实际上是一个多层的结构,通过CSS可以分别为网页的每一个层来设置样式,而最终我们能看到只是网页的最上边的一层
-总之一句话,CSS用来设置网页中元素的样式
使用CSS来修改元素的样式
-第一种方式(内联样式/行内样式)不推荐使用:
-在标签内部通过style属性来设置元素的样式
-使用内联样式,样式只能对一个标签生效,多个标签同时使用时,不方便维护
-注意:开发时绝对不要使用内联样式
-第二种方式(内联样式表):
-将样式编写到head的style标签里,然后通过CSS选择器来选中元素并为其设置各种格式,可以为多个标签设置样式,并且只需要修改一处即可
-内部样式表更加方便对样式进行复用
-注意:内联样式表只能对一个网页起作用,它里面的样式不能跨网页复用
-第三种方式(外部样式表)最佳实践:
-可以将CSS样式编写到一个外部的CSS文件中,然后通过link标签引入外部的CCS文件
-外部样式表需要通过link标签来引人,意味着只要想使用这些样式的网页都可以对其进行引用,使样式可以在不同页面之间进行复用
-将样式编写到外部的CSS文件中,可以使用到浏览器的缓存机制,从而加快网页的加载速度,提高用户体验
CSS的基本语法
-选择器:
-通过选择器可以选中页面中的指定元素
-声明块:
- 通过声明块来指定要为元素设置的样式
- 声明块由一个一个的声明组成
- 声明块时一个名值对结构,一个样式名对应一个样式值,名和值之间以: 连接,以; 结尾
-常用选择器
-元素选择器:
作用:根据标签名来选中指定的元素
语法:标签名{}
例子:p{} h1{} div{}
-id选择器:
作用:根据元素的id属性值选中一个元素
语法:#id属性值{}
例子:#abc{}
-class选择器是一个标签的属性,它和id类似,不同的是class可以重复使用,可以通过classs属性来为元素分组
-通配选择器:
作用:选中页面的所有元素
语法:*
-交集选择器:
作用:选中同时复合多个条件的元素
语法:选择器1选择器2选择器3...选择器n{}
注意:交集选择器中的所有元素选择器,必须使用元素选择器开头
例子:div.red{}
-并集选择器(选择器分组):
作用:同时选择多个选择器对应的元素
语法:选择器1,选择器2,选择器3,...,选择器n{}
例子:#abc,p,div.red{}
-关系选择器
父元素:直接包含了子元素的元素叫父元素
子元素:直接被父元素包含的元素叫子元素
祖先元素:直接或间接包含后代元素的元素叫祖先元素,一个元素的父元素也是它的祖先元素
后代元素:直接或间接被祖先元素包含的元素叫后代元素,子元素也是后代元素
兄弟元素:拥有相同父元素的兄弟元素
-子元素选择器:
作用:选中指定父元素的指定元素
语法:父元素>子元素
例子:div.red > span{}
-后代元素选择器:
作用:选中指定元素内的指定后代元素
语法:祖先 后代
例子:div span{}
-兄弟元素选择器:
-选择下一个兄弟
语法:前一个 + 后一个
例子:p + span{}
-选择下面所有兄弟
语法:兄 ~ 弟
例子:p ~ span
-属性选择器
[属性名] 选择含有指定属性的元素
[属性名=属性值] 选择含有指定属性和属性值的元素
[属性名^=属性值] 选择属性值以指定值‘开头’的元素
[属性名$=属性值] 选择属性值以指定值‘结尾’的元素
[属性名*=属性值] 选择属性值中’含有某值‘的元素的元素
-伪类选择器
伪类(不存在的类,特殊的类)
-伪类用来描述一个元素的特殊状态
例如:一个子元素,被点击的元素,鼠标移入的元素...
-伪类一般情况下都是使用: 开头
:first-child 第一个子元素
:last-child 最后一个子元素
:nth-child() 选中第n个子元素
特殊值:
n(第n个)n的范围0到正无穷
2n 或者 even 表示选中偶数位的元素
2n+1 或者 odd 表示选中奇数位的元素
-以上这些伪类都是根据所有的子元素进行排序
:first-of-type
:last-of-type
:nth-of-type()
-这几个伪类的功能和上述的类似,不通点是他们是在'同类型元素中'进行排序
例如: ul > li:first-of-type
-:not()否定伪类,将符合条件的元素从选择器中去除
-a标签相关(超链接)的伪类
- a:link 用来表示没有访问过的链接(正常的链接)
- a:visited 用来表示访问过的链接
由于隐私的原因,所以visited这个伪类只能修改链接的颜色
- :hover 用来表示鼠标移入的状态
- :active 用来表示鼠标点击
-伪元素
伪元素表示页面中一些特殊的并不真实存在的元素(特殊位置)
伪元素使用 :: 开头
::first-letter 表示第一个字母
::first-line 表示第一行
::selection 表示选中的内容
::before 元素的开始
::after 元素的结束
before和after 必须结合content属性来使用
例如:div::before{content: "abc";}
选择器的权重:
样式的冲突:当我们通过不同的选择器,选中相同的元素,并且为相同的样式设置不同的值时,此时发生了样式的冲突。
发生样式冲突时,应用哪个样式由选择器的权重(优先级)决定
选择器的权重: 优先级
内联样式 1,0,0,0
id选择器 0,1,0,0
类和伪类选择器 0,0,1,0
元素选择器 0,0,0,1
通配选择器 0,0,0,0
继承的样式 没有优先级
比较优先级,需要将所有的选择器的优先级进行相加计算,最后优先级越高,则越优先显示(分组选择器是单独计算的)
-选择器的累加不会超过其最大的数量级,类选择器再高不会超过id选择器(不会超过前一位)
-如果优先级计算后相同,此时则优先使用靠下的样式
可以在某一个样式的后面添加 !important,则此时该样式会获得到最高的优先级,甚至超过内联样式(注意:在开发中一点要慎用)
-
继承
-
样式的继承,我们为一个元素设置的样式同时也会应用到它的后代元素上
-
继承是发生在祖先的后后代之间的
-
继承的设计是为了方便我们的开发,利用继承我们可以将一些通用的样式统一设置到共同的祖先元素上,这样只需设置一次就可以让所以元素继承样式
-
注意:并不是所有样式都会被继承:
比如:背景相关的,布局相关等的这些样式都不会被继承。
像素和百分比
-
长度单位:像素(px)
-屏幕(显示器)实际上上由一个一个的小点点构成的
-不同屏幕的像素大小是不同的,像素越小的屏幕显示的效果越清晰
-所以同样的200px在不同的设备下显示效果不一样 -
百分比:
-也可以将属性值设置为相对于其父元素属性的百分比
-设置百分比可以使子元素跟随父元素的改变而改变 -
em:
-em是相对于元素的字体大小来计算的
-1em = 1front-size
-em 会根据字体大小的改变而改变 -
rem:
-rem 相对于根元素的字体大小来计算的
RGB值
颜色单位:
在CSS中可以直接使用颜色名来设置各种颜色
- 比如:red,blue,yellow…
- 但是在CSS中直接使用颜色名是非常的不方便
RGB值:
- RGB通过三种颜色的不同浓度来调配出不同的颜色
- R red, G green, B blue
- 每一种颜色的范围在0~255(0%~100%)之间
- 语法:RGB( 红色,绿色,蓝色 )
RGBA:
- 就是在RGB的基础上增加了一个a表示不透明度
- 需要四个值,前三个和rgb一样,第四个表示不透明度
- 1表示完全不透明 0表示完全透明 .5表示半透明
十六进制的RGB值:
- 语法:#红色绿色蓝色
- 颜色浓度通过 00-ff(最大)
- 如果颜色两位两位重复可以进行简写,例如:#aabbcc --> #abc
HSL值/HSLA值:
- H 色相(0~360)
- S 饱和度,颜色的浓度(0%~100%)
- L 亮度,颜色的亮度(0%~100%)
文档流
文档流(normal flow)
- 网页是一个多层的结构,一层夹着一层
- 通过CSS可以分别为每一层来设置样式
- 作为用户来讲只能看到最顶上一层
- 这些层,最底下的一层称为文档流,文档流是网页的基础
我们所创建的元素默认都是在文档流中进行排列
- 对于我们来说,元素主要有两个状态:
·在文档流中
·不在文档流中(脱离文档流)
- 元素在文档流中有什么特点?
-块元素
- 块元素会在页面中独占一行
- 默认宽度是父元素的全部(会把父元素撑满)
- 默认高度是被内容撑开(子元素)
- 行内元素
- 行内元素不会独占页面的一行,只占自身的大小
- 行内元素在页面中自左向右水平排列,如果一行之中不能容纳下所有的行内元素,则元素会换到第二行继续自左向右排列(书写习惯一致)
- 行内元素的默认宽度和高度都是被内容撑开
盒子模型
·盒模型、盒子模型、框模型(box model)
- CSS将页面中的所有元素都设置成为一个矩形的盒子
- 将元素设置为矩形的盒子后,对页面的布局将变成将不同的盒子摆放到不同的位置
- 每一个盒子都有以下几个部分组成:
1. 内容区(content)
元素中的所有的子元素和文本内容都在内容区中排列
内容区的大小由width和height两个属性来设置
width:设置内容区的宽度
height:设置内容区的高度
2. 内边距(padding)
3. 边框(border)
边框属于盒子边缘,边缘里边属于盒子内部,出了边框都是盒子的外部(边框的大小会影响整个盒子的大小)
要设置边框,需要至少设置三个样式:
边框的宽度 border-width
边框的颜色 border-color
边框的样式 border-style
4. 外边距(margin)
·盒子模型-边框
-border-width:
默认值:一般为3个像素
border-width 可以用来指定四个方向的边框的宽度
值的情况:
四个值:上 右 下 左
三个值:上 左右 下
两个值:上下 左右
一个值:上下左右
除了border-width还有一组 border-xxx-width (xxx可以是top right bottom left-用来单独指定某一个边的宽度)
-border-color:
border-color 用来指定边框的颜色,同样可以分别指定四个边的边框(规则和border-width一样)
border-color也可以省略不下,如果省略了则自动使用color的颜色值
-border-style:
border-style指定边框的样式
solid表示实线
dotted表示点状虚线
dashed表示虚线
double表示双线
border-style的默认值是none,表示没有边框
-border简写属性,通过该属性可以同时设置边框所有的相关样式,并且咩呀顺序要求
除了border意外还有四个 border-xxx (top, right, bottom, left )
·盒子模型-内边距
内边距(padding):
- 内容区和边距之间的距离是内边距
padding:上 右 下 左
- 一共有四个方向的内边距:
padding-top
padding-right
padding-bottom
padding-left
- 内边距的设置会影响到盒子的大小
- 背景颜色会延伸到那边啥内边距上
- 一个盒子的可见框的大小,可由内容区,内边距和边框共同决定
所以在计算盒子大小时,还需要将这三个区域加到一起计算
·盒子模型-外边距
外边距(margin):
- 外边距不会影响盒子可见框的大小
- 但是外边距会影响盒子的位置
- 一个有四个方向的外边距
margin-top
-上外边距,设置一个正值,元素会向下移动
margin-right
-默认情况下设置margin-right不会产生任何效果
margin-bottom
-下外边距,设置一个正值,其下边的元素会向下移动
margin-left
-左外边距,设置一个正值,元素会向右移动
(margin也可以设置为负值,如果是负值则元素会向相反方向移动)
-元素在页面中说按照自左向右的顺序排列的
所以默认情况下如果我们设置的左和上外边距则会移动自身元素
而设置右和下外边距会移动其他元素
- margin的简写属性:
margin 可以同时设置四个方向的外边距,用法和padding一样
-margin 会影响到盒子实际占用的空间
·盒子模型-水平方向的布局
元素的水平方向的布局:
元素在其父元素中水平方向的位置由以下几个属性共同决定:
margin-left
border-left
padding-left
width
padding-right
border-right
margin-left
一个元素在其父元素中,水平布局 ‘必须要满足’ 以下的等式:
margin-left + border-left + padding-left + width + padding-right + border-right + margin-left = 其父元素内容区的宽度(必须满足)
-以上等式必须满足,如果相加结果使等式不成立,则称为过度约束,则等式会自动调整
-调整的情况:
-如果这七个值中没有为auto的情况,则浏览器会自动调整margin-right的值使等式满足(当子元素宽度大于父元素宽度时,margin-right的值为负数)
-这七个值中有三个值课设置为auto
width
margin-left
margin-right
-如果某个值为auto,则会自动调整为auto的那个值来使等式成立
-如果将一个宽度和一个外边距设置为auto,则宽度会调整到最大,设置为auto的那个外边距会自动为0
-如果将三个值都设置为auto,则外边距都是0,宽度最大
-如果将两个两个外边距设置为auto,宽度固定值,则回将两个外边距设置为相同的值
我们经常利用这个特点来使一个元素在其父元素中水平居中
例子:
margin: xxpx;
margin: 0 auto;
·盒子模型-垂直方向的布局
-默认情况下父元素的高度被内容撑开
- 子元素是父元素的内容区中排列的:
如果子元素的大小超过了父元素,则子元素会从父元素中溢出
使用 overflow 属性来设置父元素如何处理溢出的子元素
可选值:
visible:默认值 子元素会从父元素中溢出,在父元素外部的位置显示
hidden:溢出内容将会被裁剪不会显示
scroll:生成两个滚动条,通过滚动条来查看完成整内容
auto:根据需要生成滚动条
·盒子模型-外边距的重叠(折叠)
-相邻的垂直方向外边距会发生重叠现象
-兄弟元素
-兄弟元素间的相邻垂直外边距会取两者之间的较大值(两者都是正值)
-特殊情况:
如果相邻的外边距一正一负,则取两者的和
如果相邻的外边距都是负值,则取两者中绝对值较大的
-兄弟元素之间的外边距的重叠,对于开发是有利的,所以我们不需要进行处理
-父子元素
- 父子元素之间相邻外边距,子元素的会传递给父元素(上外边距)
- 父子外边距的折叠会影响到页面的布局,必须要进行处理
·盒子模型-行内元素
- 行内元素不支持设置宽度和高度
- 行内元素可以设置padding,但是垂直方向padding不会影响页面的布局
- 行内元素可以设置border,垂直方向的border不会影响页面的布局
- 行内元素可以设置margin,垂直方向的margin不会影响页面的布局
- display 可以用来设置元素显示的类型
可选值:
inline:将元素设置为行内元素
block: 将元素设置为块元素
inline-block:将元素设置为行内块元素
行内块元素,即可以设置宽度和高度又不会独占一行
table:将元素设置为一个表哥
none:元素不在页面中显示
- visibility 可以用来设置元素显示状态
可选值:
visible(默认值):元素在页面正常显示
hidden:元素在页面中隐藏(不显示),但是依然占据页面的位置
·高度塌陷和BFC
高度塌陷的问题:
- 在浮动布局中,父元素的高度默认是被子元素撑开的,当子元素浮动后,其会完全脱离文档流,子元素从文档流中脱离,将会无法撑起父元素的高度,导致父元素的高度丢失。
- 父元素高度丢失以后,其下的元素会自动上移,导致页面的布局混乱
- 高度塌陷是浮动布局中比较常见的一个问题,这个问题我们必须要进行处理
BFC ( Block Formatying Context ) 块级格式化环境
-BFC是一个CSS中的一个隐含的属性,可以为一个元素开启BFC
开启BFC该元素会变成一个独立的布局区域
- 元素开启BFC后的特点:
1. 开启BFC的元素不会被浮动元素所覆盖
2. 开启BFC的元素的子元素和父元素外边距不会重叠
3. 开启BFC的元素可以包含浮动的子元素
-可以通过一些特殊方式来开启元素的BFC:
1. 设置元素的浮动(不推荐)
2. 将元素设置为行内块元素(不推荐)
3. 将元素的overflow设置为一个非visible的值
-常用方式:为元素设置overflow: hidden 开启BFC(以使其可以包含浮动元素)
· clear
- 如果我们不希望某个元素因为其他元素浮动的影响而改变位置,可以通过clear属性来清除元素对当前元素所产生的影响
- clear:
- 作用:清除浮动元素对当前元素所产生的影响
- 可选值:
left:清除左侧浮动元素对当前元素的影响
right:清除右侧浮动元素对当前元素的影响
both:清除两侧浮动元素影响最大的那侧
·高度塌陷的最终解决方案(使用after伪类)
.box::after{
content: '';
display: block;
clear: both;
}
解决高度塌陷和外边距重叠(同时解决方案):
.clearfix::before,
.clearfix::after{
content: '';
display: table;
clear: both;
}
定位
定位(position)
- 定位是一种更加高级的布局手段
- 通过定位可以将元素摆放到页面的任意位置
- 使用position属性来设置定位
可选值:
static:默认值,元素是静止的没有开启定位
relative:开启元素的相对定位
absolute:开启元素的绝对定位
fixed:开启元素的固定定位
sticky:开启元素的粘滞定位
- 相对定位(position: relative):
- 当元素的position属性值设置为relative时则开启了元素的相对定位
- 相对定位的特点:
1. 元素开启相对定位以后,如果不设置偏移量元素不会发生任何的变化
2. 相对定位时参照于元素在文档流中的位置进行定位的
3. 相对定位会提升元素的层级
4. 相对定位不会使元素脱离文档流
5. 相对定位不会改变元素的性质块还是块,行内还是行内
- 偏移量(offset)
- 当元素开启了定位以后,可以通过偏移量来设置元素的位置
top:-定位元素和定位位置上边的距离
bottom:- 定位元素和定位位置下边的距离
- 定位元素垂直方向的位置由top和bottom两个属性来控制
- 通常情况下我们只会使用其中之一
- top值越大,定位元素越向下移动
- bottom值越大,定位元素越向上移动
left:-定位元素和定位位置的左侧的距离
right: -定位元素和定位位置的右侧的距离
- 定位元素垂直方向的位置由left和right两个属性来控制
- 通常情况下我们只会使用其中之一
- left值越大,定位元素越向右移动
- right值越大,定位元素越向左移动
-绝对定位(position: absolute; )
-当元素的position属性值设置为absolute时,则元素开启了元素的绝对定位
- 绝对定位的特点:
1. 开启了绝对定位后,如果不设置偏移量元素的位置不会发生变化
2. 开启绝对定位后,元素会从文档流中脱离
3. 绝对定位会改变元素的性质,行内元素变成块,块的宽度和高度被内容撑开
4. 绝对定位会使元素提升一个层级
5. 我们的绝对定位元素使相对于其包含块元素进行定位的
包含块元素(containing block)
- 正常情况下:
包含块就是离当前元素最近的祖先快元素
例如:<div><span></span></div>
- 绝对定位的包含块:
包含块就是离它最近的开启了相对定位的祖先元素,如果所有的祖先元素都没有开启相对定位则根元素就是它的包含块
- html (根元素、初始包含块)
-固定定位(position: fixed; )
- 将元素的position属性设置为fixed则开启了元素的固定定位
- 固定定位也是一种绝对定位,所以固定定位的大部分特点都和绝对定位一样
- 唯一不同的是,固定定位永远参照于浏览器的视口进行定位
固定定位的元素不会随着页面的滚动条滚动
- 粘滞定位(position: sticky)
- 当元素的position属性设置为sticky时则开启了元素的粘滞定位
- 粘滞定位和相对定位的特点基本一样,不同的是粘滞地位可以在元素到达某个位置时将其固定
- 绝对定位元素的布局
- 水平布局
- 垂直方向布局的等式必须满足
left + margin-left + border-left + padding-left + width + padding-right + border-right + margin-left + right = 其父元素内容区的宽度
- 当我们开启了绝对定位后:
- 水平方向的布局等式就要添加 left 和 right 两个值,此时规则和之前一样,只是多添加了两个值。
- 当发生过度约束:
如果9个值中没有 auto则自动调整right 的值以使等式满足
如果有auto, 则自动调整auto的值使等式满足
-可设置auto的值:
margin width left right
-因为left 和right 的值默认是auto,所以如果不知道left和right的值,则等式不满足时,会自动调整这两个值
- 垂直布局
- 垂直方向布局的等式必须满足
top + margin-top/bottom +padding-top/bottom + border-top/bottom + height = 包含块的高度
- 元素的水平垂直居中代码:
.box{
margin: auto;
top:0;
bottom:0;
left:0;
right:0;
}
元素的层级
对于开启了定位元素,可以通过z-index属性来指定元素的层级 :
- z-index需要一个整数作为参数,值越大元素的层级越高,元素的层级越高越优先显示
- 如果元素的层级相同,会优先显示靠下的元素
- 祖先元素的层级再高也不会盖住后代元素
字体族
字体相关的样式:
color:用来设置字体颜色
font-size:用来设置字体的大小
- 和font-size相关的单位:
em相当于当前元素的一个font-size
rem相当于根元素的一个font-size
- font-family 字体族(字体样式)
可选值:
serif:衬线字体
sans-serif:非衬线字体
monospace:等宽字体
- 指定字体的类别,浏览器会自动使用该类别下的字体
- font-family 可以同时指定多个字体,多个字体间使用,隔开
字体生效时优先使用第一个,第一个无法使用则使用第二个,以此类推
-font-face 可以将服务器中的字体直接提供给用户去使用
- 问题:
1. 加载速度
2. 版权问题
- 用法:
@font-face{
font-family: 'myfont';
src: url('./路径');
}
图片字体
· 图片字体(iconfront)
-在网页中经常需要使用一些图标,可以通过图片来引入图标
但是图片的大小本身比较大,并且非常不灵活
- 所以在使用图片时,我们还可以将图片直接设置为字体,然后通过font-face的形式来对字体进行引入
- 这样我们可以通过使用字体的样式的形式来使用图标
· fontawesome 使用步骤:
1. 下载https://fontawesome.com/
2. 解压
3. 将css和webfonts移动到项目中
4. 将all.css引入到网页中
5. 使用图标字体
- 直接使用类名来使用图标字体
· 图标字体的其他使用方式
通过伪元素来设置图标字体
1. 找到要设置图标的元素通过before或after选中
2. 在content中设置字体的编码
3. 设置字体的样式:
fab:
font-family: 'Font Awesome 5 Brands'
fas:
font-family: 'Font Awesome 5 Brands';
font-weight: 900;
4. 通过实体来使用图标字体:
&#( 图标的编码 );
· 阿里字体图标库( iconfront)
行高
行高(line height)
- 行高指的是文字占有的实际高度
- 可以通过line-height来设置行高
行高可以直接指定一个大小(px em),也可以直接为行高设置一个整数
如果是一个整数的话,行高将会是字体的指定的倍数
- 行高经常还用来设置文字的行间距
- 行间距 = 行高 - 字体大小
字体框
- 字体框就是字体存在的格子,设置font-size实际上就是在设置字体框的高度
- 行高会在字体框的上下平均分配
通常将行高设置为和高度一样的值,使单行文字在一个元素中垂直居中
字体的简写属性
· font 可以设置字体相关的所有属性
语法:
font :字体大小/行高 字体族 (行高可以省略不写,如果不写会使用默认值)
· font-weight 字重,字体的加粗
可选值:
normal:默认值,不加粗
bold:加粗
100-900 九个级别(没有区别)
· font-style 字体的风格
normal 正常的
italic 斜体
文本的水平和垂直对齐
· text-align:文本的水平对齐
可选值:
left:左侧对齐
right:右侧对齐
center:居中对齐
justify:两端对齐
· vertical-align:文本的垂直对齐
可选值:
baseline:默认值,基线对齐
top:顶部对齐
bottom:底部对齐
middle:居中对齐
· 其他的文本样式
- text-decoration:设置文本修饰
可选值:
none:什么都没有
underlin:下划线
line-through:删除线
overline:上划线
- white-space:设置网页如何处理空白
可选值:
normal:正常
nowrap:不换行
pre:保留空白
背景
· background-color(设置背景颜色)
· backgro-image(设置背景图片)
- 可以同时设置背景图片和背景颜色,这样背景颜色将会将会成为背景图片的背景色
- 如果背景图片小于元素,则背景图片会自动在元素中平铺,将元素铺满
- 如果背景的图片大于元素,将会一个部分背景无法完全显示
- 如果背景图片和元素一样大,则会直接正常显示
· background-repeat(用来设置背景的重复方式)
可选值:
repeat :默认值,背景会沿着x轴 y轴双方向重复
repeat-x:沿着x轴的方向重复
repeat-y:沿着y轴的方向重复
no-repeat:背景图片不重复
· background-position(用来设置背景图片的位置)
可选值:
- 通过 top left right bottom center 几个表示方位的词来设置背景图片的位置
- 使用方位词时必须同时指定两个值,如果只写一个则第二个默认就是center
- 通过偏移量来设置背景图片的位置:
水平方向的偏移量,垂直方向的偏移量
· background-clip(设置背景的范围)
可选值:
border-box:默认值,背景会出现在边框的下边
padding-box:背景不会出现在边框,只出现在内容区和边框
content-box:背景只会出现在内容区
· background-origin(背景图片的偏移量计算的原点)
可选值:
padding-box:默认值,background-position从内边距处开始计算
content-box:背景图片的偏移量从内容区开始处计算
border-box:背景图片的变量从边框处开始计算
· background-size(设置背景图片的大小)
- 第一个值表示宽度
- 第二个值表示高度
- 如果只写一个值,则第二个值默认是auto
- cover:图片的比例不变,将元素铺满
- contain:图片的比例不变,将图片在元素中完整显示
· background-attachment(背景图片是否跟随元素移动)
可选值:
scroll:默认值,背景图片会跟随元素移动
fixed:背景图片会固定在页面中,不会随元素移动
· background背景相关的简写属性,所有背景相关的样式都可以通过该样式来设置,并且该样式没有顺序要求,也没有哪个属性是必须写的
· 注意:
- background-size:必须写在background-position的后面,并且使用/隔开
background-position/background-size
- background-origin background -clip两个样式,origin必须在clip的前面
· 图片闪烁问题:
- 图片属于网页中的外部资源,外部资源都需要浏览器单独发送请求加载,浏览器加载外部资源时是按需加载的(用则加载,不用则不加载)
- 解决图片闪烁的问题:
1. 可以将多个小图片统一保存到一个大图片中,然后通过调整backgr-position开显示相应的图片
2. 这样图片会同时加载到网页中,就可以有效的避免来闪烁问题
3. 这个技术在网页中的应该十分广泛,被称为CSS-Sprite,这种图我们称为雪碧图
· 线性渐变
- 通过渐变可以设置一些复杂的背景颜色,可以实现从一个颜色向其他颜色过渡的效果
!!渐变是图片,需要通过background-image来设置
- 线性渐变,颜色沿着一条直线发生变化 linear-gradient()
例子:linear-gradient(red,yellow)红色在开头,黄色在结尾,中间是过渡区域
- 线性渐变的开头,我们可以指定一个渐变的方向
to left: 向左
to right:向右
to bottom:向下
to top:向上
xxxdeg (deg表示度数)
turn (表示圈)
- 渐变可以同时指定多个颜色,多个颜色默认情况下平均分布
repeating-linear-gradient()可以平铺的线性渐变
· 径向渐变
radial-gradient()径向渐变(放射性的效果)
- 默认情况下,径向渐变圆心的形状根据元素的形状来计算的
正方形-->圆形
长方形-->椭圆形
-我们也可以手动指定径向渐变的大小,也可以指定渐变的位置
- 语法:
radial-gradient(大小 at 位置,颜色 位置,颜色 位置...)
- 大小:
circle:圆形
ellipse:椭圆
closet-side:近边
closet-corner:近角
farthest-side:远边
farthest-corner:远角
- 位置:
top right left center bottom
雪碧图
- 雪碧图的使用步骤:
1. 先确定要使用的图标
2. 测量图标的大小
3. 根据测量结果创建一个元素
4. 将雪碧图设置为元素的背景图片
5. 设置一个偏移量以显示正常的图片
- 雪碧图的特点:
一次性将多个图片加载进页面,降低请求的次数,加快访问速度,提升用户体验
<br></br>
表格的简介
- 在我们现实社会中,我们经常需要使用表格表示一些格式化数据(课程表、人名单、成绩单...)
- 表格的创建
- 同样在网页中我们也需要使用表格,我们通过table标签来创建一个表格
- 在table中使用tr表示表格中的一行,有几个tr就有几行
- 在tr中使用td表示一个单元格,有几个td就有几个单元格
- colspan 横向的合并单元格
- rowspan 纵向的合并单元格
- 长表格
可以将一个表格分成三个部分:
头部:thead
主体:tbody
底部:tfoot
- 表格的样式
border-spacing:指定边框之间的距离
border-collapse:collapse;设置边框的合并
- 如果表格中没有使用tbody而是直接使用tr,那么浏览器会自动创建一个tbody,并且将全部tr都放到tbody
- tr不是table的子元素
- 默认情况下元素在td中是垂直居中的,可以通过vertical-align来调整
- 将元素设置为单元格
display: table-cell;
vertical-align: middle;
<br></br>
表单
- 表单在我们的现实生活中用于提交数据
- 在网页中也可以使用表单,网页中的表单用于将本地的数据提交给远程的服务器
- 使用form标签来创建一个表单
- form的属性:
action:指定表单要提交的服务器的地址
- 表单项
- 文本框(<input type="text" name="username">):
注意:数据要提交到服务器中,必须要为元素指定一个name属性值
- 密码框(<input type="passward" name="userword">)
- 单选按钮(<input type="radio" name="名字">):
像这种选择器,必须要指定一个value属性,value属性最终会作为用户的填写的值传递给服务器
- 多选框(<input type="checkbox" name="名字">)
- 下拉列表(<select name="名">
<option value="值1">选项一</option>
<option selected(默认选中) value="值2">选项二</option>
</select>)
- 提交按钮(<input type="submit" value="值">)
- 重置按钮(<input type="reset">)
- 普通按钮(<input type="button" value="值">)
- 按钮中的属性
- autocomplete="on/off" 开启/关闭自动补全
- readonly 将表单项设置为只读,数据会提交
- disabled 将表单项设置为禁用,数据不会提交
- autoforce 设置表单项自动获取焦点
默认样式
- 通常情况下,浏览器都会为元素设置一些默认样式
- 默认样式的存在会影响到页面的布局
通常情况下编写网页时必须要去除浏览器到默认样式(pc端端页面)
-重置样式表,专门用来对浏览器到样式进行重置的
reset.css 直接去除来浏览器到默认样式
normalize.css 对默认样式进行了统一