CSS3

CSS3
网页分成三个部分

结果(HTML)

表现(CSS)

行为(javascript)

CSS

层叠样式表

网页实际上是一个多层的结果,通过CSS可以分别为王爷的每一层设置样式

最终我们能看到的只是网页最上面一层

总之一句好,CSS用于来设置网页中元素的样式

CSS基础使用
使用CSS来修改元素的样式
第一种样式(内联样式,行内样式):
在标签内部通过style属性来设置元素的样式

问题:

使用内联样式,样是只能对一个标签生效
如果虚妄影响到多个元素必须在每一个元素中都复制一遍
并且当样式发生变化时,我们必须要一个一个的修改,非常的不方便
-注意:开发时绝对不要使用内联样式

1

少小离家老大回,乡音未改鬓毛哀

第二种样式(内部样式表): 将样式编写到head中的style标签中

然后通过CSS的选择器来选中元素并为其设置各种样式

可以同时为多个标签设置样式,并且修改时只需要修改一处即可

内部样式表更方便对样式进行复用

第三种方式(外部样式表) 最佳实践:
可以将CSS样式编写到一个外部的CSS文件中

然后通过link标签来引入外部的CSS文件

外部样式表需要通过link标签进行引入,意味着只要想使用这些样式的网页都可以对其引用

使样式可以在不同页面之间进行复用

将样式编写到外部的CSS文件中,可以使用到浏览器的缓存机制

从而加快网页的加载速度,提高用户的体验

1

CSS注释 1 /* 2 CSS的注释,注释的内容会自动被浏览器忽略 3 */ CSS选择器 标签选择器

类选择器

id选择器

通配选择器

class 是一个标签的属性,他和id类似,不同的是class可以重复使用

可以通过classs属性来为元素分组

可以同时为一个元素指定多个class属性

通配符选择器:

选中页面中的所有元素

复合选择器
交集选择器
选中同时复合多个条件的元素

选择器1选择器2选择3选择器n{}

注意:交集选择器中如果有元素选择器,必须使用元素选择器开头

选择器分组(并集选择器)
同时选择多个选择器对应的元素
选择器1,选择器2,选择器3,选择器n{}

关系选择器
父元素

直接包含子元素的元素叫做父元素

子元素

直接被父元素包含的元素是子元素

祖先元素

直接或间接包含后代元素的元素叫做祖先元素

一个元素的父元素也是他的祖先元素

后代元素

直接或间接被祖先元素包含的元素叫做后代元素

子元素也是后代元素

兄弟元素

拥有相同父元素的元素时兄弟元素

子元素选择器:

作用:选择指定父元素的指定子元素

语法:父元素 > 子元素

后代元素选择器

作用:选中指定元素内的指定后代元素

语法:祖先 后代

选择下一个兄弟

语法:前一个 + 下一个

选择下边所有的兄弟

语法:兄 ~ 弟

[属性名] 选择含有指定属性的元素
[属性名=属性值] 选择含有指定属性和属性值的元素
[属性名^=属性值] 选择属性值以指定开头的元素
[属性名$=属性值] 选择属性值以指定结尾的元素
[属性名*=属性值] 选择属性值中含有某些元素的元素

伪类选择器
伪类(不存在的类,特殊的类)

伪类用来描述一个元素的特殊状态

比如:第一个子元素、被点击的元素、鼠标移入的元素...

伪类一般情况下都是使用:开头

:first-child
以上这些伪类都是根据所有的子元素进行排序

:first-of-type
:last-of-type
:nth-of-type()
这几个伪类的功能和上述的类似,不同点他们是在同类型元素中进行排序

:first-child
第一个子元素

last-child
最后一个子元素

nth-child(n)
选中第n个子元素,属性指定
特殊值:n,n的范围0~∞
2n 或 even,表示选中偶数位的元素
2n+1 或 odd,表示选中奇数位的元素

:not()否定伪类
将符合条件的元素从选择器中去除

超链接的伪类
未访问过的链接 蓝色

已访问过的链接

:link
用来表示没访问过的链接(正常的链接)

:visited
用来表示已访问过的链接
由于隐私的原因,所以visited这伪类只能修改链接的颜色

:hover
用来表示鼠标移入的状态

:active
用来表示鼠标点击的状态

伪元素
表示页面的一些特殊的并不真实存在的元素(特殊的位置)
伪元素的使用 :: 开头

::first-letter
表示第一个字母

::first-line
表示第一行

::selection
表示选中的内容

::before
表示元素的开始位置

::after
表示元素的最后位置

before和after 必须结合content属性使用,before和after经常使用

继承
样式的继承
我们为一个元素设置的样式同时也会应用到他的后代元素上
继承是发生在祖先后代之间的
继承的设计是为了方便我们的开发

利用继承我们可以将一些通用的样式统一设置到共同的祖先元素上,

这样只需要设置一次即可让所有的元素都具有该样式
注意:并不是所有的样式都会被继承

比如 背景相关,布局相关等的这些样式都不会被继承

选择器的权重
样式冲突:
当我们通过不同的选择器,选中相同的元素,并且为相同的样式设置不同的值时,此时就发生了样式的冲突

发生样式冲突时,应用哪个样式由选择器的权重(优先级)决定

选择器的权重:
内联样式 1,0,0,0

id选择器 0,1,0,0,

类和伪类选择器 0,0,1,0

元素选择器 0,0,0,1

通配选择器 0,0,0,0

继承的样式 没有优先级
比较优先级时,需要将所有的选择器的优先级进行相加计算,最后优先级越高,则越优先显示(分组选择器是单独计算的)
选择器的累加不会超过其最大的数量级,类选择器再高也不会超过id选择器
如果优先级计算后相同,此时则优先使用靠下的样式

可以在某一个样式的后面添加 !important ,则此时该样式会获取到最高的优先级,甚至超过内联样式
注意:在开发中这个玩意儿一定要慎用!
继承没有优先级

像素与百分比
长度单位:
像素

屏幕(显示器)实际上是由一个一个的小点点构成的

不同屏幕的像素大小是不同的,像素越小的屏幕显示的效果越清晰

所以同样的200px在不同的设备下显示效果不一样

百分比:

也可以将属性值设置为相对于父元素属性的百分比

设置百分比可以是子元素跟随父元素的改变而改变

em

em相对于元素的字体大小来计算的

1em = 1font-size

em会根据字体大小的改变而改变

rem

rem相对于根元素的字体大小来计算

RGB值
颜色单位:

在CSS中可以直接使用颜色名来设置各种颜色

比如:red、orange、yellow、blue、green...

但是在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%

1
background-color:hsl(0,100%,100%)
文档流
网页是一个多层的结构,一层摞着一层

通过CSS可以分别为每一层来设置样式

作为用户来讲只能看到最顶上一层

这些层中,最低下的一层称为文档流,文档流是网页的基础

我们所创建的元素默认都是在文档流中进行排列

对于我们来说,元素主要有两个状态

在文档流中

不在文档流中(脱力文档流)

元素在文档流中有什么特点:

块元素

块元素会在页面中独占一行(自上向下垂直排列)

默认宽度是父元素的全部(会把父元素撑满)

默认高度是被内容撑开(子元素)

行内元素

行内元素不会独占页面一行,只占自身的大小

行内元素在页面中自左向右排列,如果一行正中,不能容纳所有的行内元素,则元素会换到第二行继续自左向右排列(书写习惯一致)

行内元素的默认宽度和高度都是被内容撑开

盒子模型
盒模型,盒子模型,框模型(box model)

CSS将页面中的所有元素都设置为了一个矩形的盒子

将元素设置为矩形的盒子后,对页面的布局就变成将不同的盒子摆放到不同的位置

每一个盒子都是由以下几个部分组成:

内容区(content)

边框(border)

内边距(padding)

外边距(margin)

内容区:

元素中的所有子元素和文本内容都在内容区中排列

width 设置内容区的宽度

height 设置内容区的宽度

边框

边框属于盒子边缘,边框里面属于盒子内部,出了边框都是盒子的外部

边框的大小会影响到整个盒子的大小

要设置边框,需要至少设置三个样式:

边框的宽度:border-width

边框的颜色:border-color

边框的样式:border-style

border-width
默认值,一般都是3个像素

border-width可以用来指定四个方向边框的宽度

四个值:上 右 下 左

三个值:上 左右 下

两个值:上下 左右

一个值:上下左右

除了border-width还有一组 border-xxx-width
xxx可以是 top right bottom left
用来单独指定某一边的宽度

border-style
指定边框的样式

solid 表示实线

dotted 点状虚线

dashed 虚线

double 双线

border简写属性
通过该属性可以同时设置边框 所有的相关样式,并且没有顺序要求

border:10px solid orange;

border-top

border-rigth

border-bottom

border-left

border-rigth:none;设置无样式

盒子模型_内边距
内边距(padding):

内容区和边框之间的距离是内边距

一共有四个方向的内边距:

padding-top

padding-rigth

padding-bottom

padding-left

内边距的设置会影响到盒子的大小

背景颜色会延伸到内边距上

一共盒子的可见框的大小,由内容区 内边距和边框共同决定,
所以在计算盒子大小时,需要将这三个区域加到一起计算

盒子模型_外边距
外边距不会影响盒子可见框的大小
但是外边距会影响盒子的位置
一共有四个方向的外边距:
margin-top
上外边距,设置一个正值,元素回向下移动
margin-right
默认情况下设置margin-right不会产生任何效果
margin-bottom
下外边距,设置一个正值,其下边的元素会向下移动
margin-left
左外边距,设置一个正值,元素会向右移动

margin的简写属性
margin 可以同时设置四个方向的外边距,用法和padding一样
margin

元素在页面中是按照自左向右的顺序排列的
所以默认情况下如果我们设置的左和上外边距则会移动元素本身
而设置下和右外边距会移动其他元素

边框的距离
border-spacing:指定边框之间的距离

border-collapse:设置边框的合并

属性值

collapse:合并所有边框

separate:合并最外部边框

水平布局
行内元素的盒模型
行内元素不支持设置宽度和高度

行内元素可以设置padding,但是垂直方向padding不会影响页面的布局

行内元素可以设置border,垂直方向的border不会影响页面的布局

行内元素可以设置margin,垂直方向的margin不会影响布局

元素的显示状态
display
用来设置元素显示的类型
可选址:
inline:将元素设置为行内元素
block:将元素设置为块元素
inline-block:将元素设置为行内块元素,行内块,既可以设置宽度和高度又不会独占一行
table:将元素设置为一个表格
none:元素不显示

visibility
用来设置元素的显示状态
可选值:
visible 默认值,元素在页面中显示
hidden 元素在页面中隐藏,不显示,但是依然占据页面的位置

默认样式的清除
默认样式:

通常情况下,浏览器都会为元素设置一些默认样式

·默认样式的存在会影响到页面的布局,通常情况下编写情况下编写页面时必须要去除浏览器的默认样式(PC的页面)

通过css直接设置
1
*{
2
margin:0
3
}
引入外部清除样式表
reset.css样式表

1

父元素中垂直居中 line-heigth 只需要将父元素的line-height设置为一个和父元素的height一样

盒子的大小
默认情况下,盒子可见框的大小由内容区、内边距和边框共同决定

box-sizing
用来设置盒子尺寸的计算方式(设置width和height的作用)

属性:
content-box 默认值,宽度和高度用来设置内容区的大小

border-box 宽度和高度用来设置整个盒子可见框的大小

width和height 指的是内容区和内边距和边框的总大小

轮廓和圆角
outline
用来设置元素的轮廓线,用法和border一样
轮廓和边框不同的点,就是轮廓不会影响到可见框的大小,轮廓不会影响布局

box-shadow
用来设置元素的阴影效果,阴影也不会影响页面的布局

第一个值:水平偏移量 设置阴影的水平位置 正值向右移动 负值向左移动

第二个值:垂直偏移量 设置阴影的垂直位置 正值向下移动 负值向上移动

第三个值:阴影的模糊半径

第四个值:阴影的颜色*

1
/**/
2
box-shadow:10px 10px 50px rgba(0,0,0,.3);
border-radius
用来设置圆角,圆角设置的圆的半径大小

border-top-left-radius

border-top-right-radius

border-bottom-left-radius

border-bottom-right-radius

border-radius 可以分别指定四个角的圆角

四个值:左上,右上,右下,左下

三个值:左上,左上/左下,右下

两个值:左上/右下,右上/左下

1
border-top-left-radius
浮动的简介
通过浮动可以使一个元素向其父元素的左侧或右侧移动

使用 float 属性用来设置于元素的浮动

可选值:

none 默认值,元素不浮动

left 元素向左浮动

right 元素向右浮动

元素设置浮动以后,水平布局的等式便不需要强制成立

元素设置浮动以后,会完全从文档流中脱离,不再占用文档流的位置

所以元素下边的还在文档流中的元素会自动向上移动

浮动的特点

浮动元素会完全脱离文档流,不再占据文档流中的位置

设置浮动以后元素会向父元素的左侧或右侧移动

浮动元素默认不会从父元素中移出

浮动元素向左或者向右移动时,不会超过他前边的其他浮动元素

如果浮动元素的上边是一个没有浮动的块元素,则浮动元素无法上移

浮动元素不会超过他上边的浮动的兄弟元素,最多就是和她一样高

简单总结
浮动目前来讲他的主要作用就是让页面中的元素可以水平排列,通过浮动可以制作一些水平方向的布局

浮动其他的特点
浮动元素不会盖住文字,文字会自动环绕在浮动元素的周围,

所以我们可以利用浮动来设置文字环绕图片的效果

元素设置浮动以后,将会从文档流中脱离,从文档流中脱离以后,元素的一些特点,也会发生变化

脱离文档流的特点:

块元素:

块元素不在独占页面的一行

脱离文档流以后,块元素的宽度和高度默认都被内容撑开

行内元素:

行内元素脱力文档流以后会变成块元素,特点和块元素一样

脱离文档流以后,不需要再区分块和行内

高度塌陷的问题
在浮动布局中,父元素的高度默认是被子元素撑开的

当子元素浮动后,其会完全脱离文档流,子元素从文档流中脱离

将会无法撑起父元素的高度,导致父元素的高度丢失

父元素丢失之后,其下的元素会自动上移,导致页面的布局混

所以高度塌陷是浮动布局中比较常见的一个问题,这个问题必须进行处理!

BFC(Block Formatting Context)块级格式化环境
BFC(Block Formatting Context)块级格式化环境

BFC是一个CSS中的一个隐含的属性,可以为一个元素开启BFC、

开启BFC该元素会变成一个独立的布局区域

元素开启BFC后的特点:

开启BFC的元素不会被浮动元素所覆盖

开启BFC的元素子元素和父元素外边距不会重叠

开启BFC的元素可以包含浮动的子元素

可以通过一些特殊方式来来开启元素的BFC:

设置元素的浮动(不推荐)

将元素设置为行内块元素(不推荐)

将元素的overflow设置为一个非visible的值

常用的方式 为元素设置 overflow:hidden 开启BFC 以使其可以包含浮动元素

clear
如果我们不希望某个元素因为其他元素浮动的影响而改变位置

可以通过clear属性来清除浮动元素对当前元素所产生的影响

clear

作用:消除浮动元素对当前元素所产生的影响

可选值:

left 清除左侧浮动元素对当前元素的影响

right 清楚右侧浮动元素对当前元素的影响

both 清除两侧中最大影响的一侧

原理:

设置清除浮动以后,浏览器会自动为元素添加一个上外边距,以使其位置不受其他元素的影响

after伪类(最终方案)
使用after在最后一个元素后创建一个content属性

清除对其的影响

将元素设置为块元素

实例:

1
.box1::after{
2
content: "";
3
clear: both;
4
display: block;
5
}
clearfix(最终的解决办法)
这个样式可以同时解决高度塌陷和外边距重叠的问题,当你遇到这些问题时,直接使用clearfix

1
.clearfixx::before,
2
.clearfix::after{
3
content:‘‘,
4
display:table;
5
clear:both;
6
}
position(定位)
定位是一种更加高级的布局手段

通过定位可以将元素摆放到页面的任意位置

使用position属性来设置定位:

可选值:

static 默认值,元素是静止的没有开启定位

relative 开启元素的相对定位

absolute 开启元素的决定定位

fixed 开启元素的固定定位

sticky 开启元素的粘滞定位

相对定位(relative)
当元素的position属性值为relative时则开启了元素的相对定位

相对定位的特点:

元素开启相对定位以后,如果不设置偏移量元素不会发生任何变化

相对定位是参照于元素在文档流中的位置进行定位的

相对定位会提升元素的层级

相对定位不会使元素脱离文档流

相对定位不会改变元素的性质,块还是快,行内还是行内

偏移量(offset):

当元素开启了定位以后,可以通过偏移量来设置元素的位置

top

定位元素和定位位置上边的距离

bottom

定位元素和定位位置下边的距离

定位元素垂直方向的位置有top和bottom两个属性来控制

通常情况下我们只会使用其一

left

定位元素和定位位置的左侧的距离

right

定位元素和定位位置的右侧距离

定位元素水平方向的位置有left和right来个属性控制

通常情况下只会使用一个

left越大元素越靠右

right越大元素越靠左

绝对定位
概念
当元素的position属性设置为absolute时,则开启了元素的绝对定位

绝对定位的特点

开启绝对定位后,如果不设置偏移量元素的位置不会发生变化

开启绝对定位后,元素会从文档流中脱离

绝对定位会改变元素的性质,行内变成块,块的宽高被内容撑开

绝对定位会使元素提升一个层级

绝对定位元素相对于其包含块进行定位的

包含块(containing block)

正常情况下:

包含块就是离当前元素最近的祖先块元素

绝对定位的包含块:

包含块就是离他最近的开启了定位的祖先元素

如果所有的祖先元素都没有开启定位,则根元素就是他的包含块

html(根元素、初始包含块)

固定定位
将元素的positon属性设置为fixed则开启了元素的固定定位

固定定位也是一种绝对定位,所以固定定位的大部分特点和绝对定位一样

唯一不同的是固定定位永远会参照于浏览器的视口进行定位

固定定位的元素不会随网页的滚动条滚动

粘滞定位
当元素的position属性设置为sticky时。则开启了元素的粘滞定位

粘滞定位和相对定位的特点基本一致。不同的是粘滞定位可以在元素到达某个位置时将其固定

绝对定位元素的位置
水平布局:

left + margin-left + border-left + padding-left + width + padding-right +border-right + margin-right

当我们开启了绝对定位后:

水平方向的不去等式就需要添加left 和 right两个值

此时规则和之前一样只是多添加了两个值:

当发生过度约束:

如果9个值中没有auto,则自动调整right值以使等式满足

可设置auto的值

margin width left right

因为left和right的值默认是auto,所以如果不知道left和right

则等式不满足时,会自动调整这两个值

垂直方向布局的等式也必须要满足

top + margin-top/bottom + padding-top/bottom + border -top/bottom + height = 包含块

元素的层级
对于开启了定位元素,可以通过z-index属性来指定元素的层级

z-index需要一个整数作为参数,值越大元素的层级越高

元素的层级越高越优先显示

如果层级一样,则优先显示最下面

祖先元素的层级再高,也不会盖住后代元素

字体
字体相关的样式
color设置字体的颜色

font-size 字体的大小

和font-size相关的单位

em 相当于当前元素的一个font-size

rem 相对于根元素的一个font-size

font-family 字体族(字体的格式)

可选值:

serif 衬线字体

sans-serif 非衬线字体

monospace 等宽字体

指定字体的类别,浏览器会自动使用该类别下的字体

font-family 可以同时指定多个字体,多个字体间使用,隔开

字体生效时优先使用第一个,第一个无法使用则使用第二个,以此类推

1
/font-face可以将服务器中的字体直接提供给用户去使用/
2
@font-face{
3
/指定字体的名字/
4
font-family:‘myFont‘;
5
src: url(‘./font/fontName‘);
6
}
图标字体(iconfont)
在网页中经常需要使用一些图标,可以通过图片来引入图标

但是图片大小本身比较大,并且非常不灵活

所以在使用图标时,我们还可以将图标直接设置为字体

然后通过font-face的形式来对字体进行引入

这样我们就可以通过使用字体的形式来使用图标

行高
行高(line height)

行高指的是文字占有的实际高度

可以通过line-height来设置行高

行高可以直接指定一个大小(px em)

也可以直接为行高设置一个整数

如果是一个整数的话,行高将会是字体的指定的倍数

大部分浏览器是的默认行高是1.33

行高经常用来设置文字的行间距

行间距 = 行高 - 字体大小

字体框

字体框就是自体存在的格子,设置font-size实际上就是在设置字体框的高度

行高会在字体框的上下平均分配

设置元素垂直居中
可以将行高设置为和高度一样的值,是单行文字在一个元素中垂直居中

字体的简写属性
font 可以设置字体相关的所有属性

语法:

font: 字体大小/行高 字体族 

行高可以省略不写 如果不写使用默认值

1
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 什么都没有

underline 下划线

line-through 删除线

overline 上划线

white-space 设置网页如何处理空白
可选值:

normal 正常

nowrap 不换行

pre 保留空白

text-overflow(溢出内容显示省略号)
可选值:

ellipsis 溢出内容显示省略号

背景
background-color
设置背景颜色

background-imge
设置背景图片

可以同时设置图片和背景颜色,这样背景颜色会成为图片的背景

如果背景的图片小于元素,则背景图片会自动在元素中平铺将元素撑满

如果背景的图片大于元素,将会是一个部分背景无法完全显示的状态

如果背景题片和元素一样大,则直接正常显示

background-repeat
用来设置背景的重复方式

可选值:

repeat 默认值,背景沿着X轴 Y轴双方向重复

repeat-x 沿着X轴方向重复

repeat-y 沿着Y轴方向重复

no-repeat 背景图片不重复

background-position
用来设置背景图片的位置

设置方式:

通过 top left right bottom center 五个方位显示

使用方位词时必须要同时指定两个值,如果只写一个,第二个默认和第一个相同

通过偏移量来制定背景图片的位置:

水平方向的偏移量 垂直方向的偏移量

background-clip
设置背景的范围

可选值:

border-box 默认值,背景会出现在边框的下边

padding-box 背景不会出现在边框,只出现在内容区和内边距

content-box 背景只会出现在内容区

background-orgin
背景图片的偏移量计算的原点

padding-box 默认值,background-position从内边距处开始计算

content-box 背景图片的偏移量从内容区处计算

background-size
设置背景图片的大小

第一个值表示宽度

第二个之表示高度

如果只写一个,则第二个默认值是auto

cover 图片的比例不变,将元素铺满,有可能位置显示不全

contain 图片比例不变,将图片在元素中完整显示

background-attachment
背景图片是否跟随元素移动

可选值:

scroll 默认值 背景图片会跟随元素移动

fiexd 背景会固定在页面中,不会随元素移动

background
背景相关的简写属性,所有背景相关的样式都可以通过样式来设置

并且该样式没有顺序要求,也咩有哪个属性是必须写的

注意:

background-size必须卸载background-position的后边,并且使用/隔开

background-position/background-seize

bbackground-origin background-clip 两个样式,origin要在clip前面

解决点击图片按钮闪烁的问题
可以将多个小图片统一保存到一个大图片中,然后通过调整background-position来显示的

这样图片会同时加载到网页中,就可以有效的避免出现闪烁的问题

这个技术在网页中应用十分广泛,被称为CSS-Sprite,这种图我们称为雪碧图

雪碧图的使用步骤:

先确定要使用的图标

测量图表的大小

根据测量结果创建一个元素

将雪碧图设置为元素的背景图片

设置一个偏移量以显示正确的图片

雪碧图的特点

一次性将多个图片加载到页面,降低请求的次数,加快访问速度,提升用户的体验

线性渐变
background-image的可选属性:

linear-gradient()

lineear-gradient(red,yellow) 红色在开头,黄色在结尾,中间是过渡区域

线性渐变的开头,我们可以指定一个渐变的方向

to left

to right

to bottom

to top

deg deg表示度数

turn 表示圈

渐变可以同时指定多个颜色,多个颜色默认情况下平均分配

repeating-linear-gradient()可以平铺的线性渐变

径向渐变
radial-gradient() 径向渐变(放射性的效果)

默认情况下,径向渐变的形状根据元素的形状来计算的

正方形 -->圆形

长方形 -->椭圆形

我们也可以手动指定径向渐变的大小

circle

ellipse

也可以指定渐变的位置

语法:

radial0gradient(大小 at 位置,颜色 位置,颜色 位置,颜色 位置)

大小:

circle 圆形

ellipse 椭圆

closest-side 近边

closest-corner 近角

farthest-side 远边

farthest-corner 远角

位置:

top right bottom left center

表格的使用
表格简介
在现实生活中,我们经常需要使用表格来表示一些格式化数据,

课程表、人名单、成绩单....

同样在网页中我们也需要使用表格,我们通过table标签来创建一个表格

在table中使用tr表示表格中的一行,有几个tr就有几行

在tr中使用td表示一个单元格,有几个td就有几个单元格

colspan 横向的合并单元格

rowspan 纵向的合并单元格

长表格
可以将一个表格分成三个部分

头部 thead

主体 tbody

底部 tfoot

表单的使用
简介
在显示生活中表单用于提交数据

在网页中也可以使用表单,网页中的表单用于将本地的数据提交给远程的服务器

form属性
action 表单要提交的服务器地址

文本框
type类型为text

注意:数据要给交给服务器中,必须要为元素指定一个name属性

密码框
type类型为password

单选按钮
type类型为radio

像这种选择框,必须指定一个value属性,value属性最终会作为用户填写的值传递给服务器

checked 可以将单选框按钮设置默认选中

多选框
type类型为checkbox

提交指定name和value属性

下拉列表
使用select标签,子标签为option,并设置value

option设置selected默认选中

提交
type类型为submit

常用设置
autocomplete="off" 关闭自动补全

readonly 将表单设置为只读,数据会提交

disabled 将表单设置为禁用,数据不会提交

autofocus 设置表单项自动获取焦点

隐藏文字常用的一个方法
text-indent

过渡效果
通过过渡可以指定一个属性发生变化时的切换方式

通过过渡可以创建一些非常好的效果,提升用户的体验

transition-property
指定要执行过渡的属性

多个属性使用,隔开

如果所有属性都需要过渡,直接使用all关键字

大部分属性都支持过渡效果,注意过渡时必须是从一个有效值向另一个有效值进行过渡

transition-duration
指定过渡效果的持续时间

时间单位:s 和 ms 1s = 1000ms

transition-timing-function
指定过渡的执行方式

可选值:

ease 默认值,慢速开始,先加速,再减速

linear 匀速运动

ease-in 加速运动

ease-out 减速运动

ease-in-out 先加速 后加速

cubic-bezier() 贝塞尔曲线,来指定时序函数(https://cubic-bezier.com

steps() 分步执行过渡效果

可以设置一个第二个值:

end:在时间结束时执行过渡(默认)

start:在时间开始时执行过渡

transition-delay
过渡效果的延迟,等待一段时间后再执行过渡

transition
可以同时设置过渡相关的所有属性,只有一个要求:如果要写延迟,两个时间中,第一个是持续时间,第二个才是延迟时间

动画
创建关键帧
1
@keyframes Test {
2
from {}
3
to {}
4
}
animation-name
动画的名字,类似方法

animation-duration
动画的执行时间

animation-timing-function
类似于过渡效果,执行方式

animation-iteration-count
动画执行的次数

可选值:

infinite 无限执行

animation-direction
指定动画运行的方向

可选值:

normal 默认值 从from向to运行,每次都是如此

reverse 从 to 向 from 运行,亦是如此

alternate 从 from 向 to运行,重复执行动画时反向执行

alternate-reverse 从 to向 from运行,重复执行动画时反向执行

animation-play-state
设置动画的执行状态

可选值:

running 默认值,动画执行

paused 动画暂停

animation-fill-mode
动画的填充模式

可选值:

none 默认值,动画执行完毕元素回到原来的位置

forwards 动画执行完毕,元素会停止在动画结束的位置

backwards 动画延时等待时,元素会处于开始位置

both 结合了forwards 和 backwards

弹性盒简介
display:flex
flex-direction
指定容器中弹性元素的排列方式

可选值:

row 默认值,弹性元素在容器中水平排列(左向右)

主轴 自左向右

row-reverse 弹性元素在容器中反向水平排列(右向左)

主轴 自右向左

column 弹性元素纵向排列(自上向下)

column-reverse 弹性元素方向纵向排列(自下向上)

主轴:

弹性元素的排列方向称为主轴

侧轴:

与主轴垂直方向的称为侧轴

弹性元素的属性
flex-grow
指定弹性元素的伸展系数

当父元素有多余空间时,子元素如何伸展

父元素的剩余空间,会按照比例进行分配

flex-shrink
指定弹性元素的收缩系数

当父元素的空间不足以容纳所有的子元素,对子元素进行收缩

可选值:

默认值 0

1

flex-wrap
设置弹性元素是否在弹性容器中自动换行

可选值:

nowrap 默认值,元素不会自动换行

wrap 元素沿着辅轴方向自动换行

wrap-reverse 元素沿着辅轴反方向换行

flex-flow
wrap和direction 的简写属性

flex-flow:row wrap;

justify-content
如何分配主轴上的空白控件(主轴上的元素如何排列)

可选值:

flex-start 元素沿着主轴起边排列

flex-end 元素沿着主轴终边排列

center 元素居中排列

space-around 空白分布到元素两侧

space-between 空白均匀分布到元素间

space-evenly 空白分布到元素的单测(兼容性不好)

align-items
元素在辅轴上如何对齐

元素间的关系

可选值

stretch 默认值,将元素的长度设为相同的值

flex-start 元素不会拉伸,沿着辅轴起边对齐

flex-end 沿着辅轴的终边对齐

center 居中对齐

baseline 基线对齐

align-content
辅轴空白空间的分布

同justly-content使用一样,只不过是辅轴相关

弹性元素
弹性的增长系数
flex-grow
弹性元素的缩减系数
缩减系数的计算比较复杂

缩减多少是根据 缩减系数 和 元素大小来计算

元素基础长度
flex-basis 指定的是元素在主轴上的基础长度

如果主轴是 横向的 则 该值指定的就是元素的宽度

如果主轴是 纵向的 则 该值指定的是就是元素的高度

默认值是 auto ,表示参考元素自身的高度或者宽度

如果传递了一个具体的数值,则以该值为准

flex
可以同时设置弹性元素所有的是三个样式

flex 增长 缩减 基础;

initial “flex:0 1 auto”.

auto "flex:1 1 auto".

none "flex: 0 0 auto"弹性元素没有弹性

order
决定弹性元素的排列顺序

perspective:设置近大远小效果

是否显示元素的背面

backface-visibility:hidden visible

像素
vm作为像素单位

媒体查询
语法:@media 查询条件{}

媒体类型:

all 所有设备

print 打印设备

screen 带屏幕的设备

speach 屏幕阅读器

累哦时间偶跑迷宫

可以使用,连接多个媒体类型,这样他们之间就是一个或关系

可以在媒体类型前添加一个only,表示只有

only的使用主要是为了兼容一些老版本的浏览器

断点
样式切换的分界点,我们称其为断点,也就是网页的样式会在这个点发生变化

一般比较常用的断点

小于768 超小屏幕 max-width=768px

大于768 小型屏幕 min-width=768px

大于992 中型屏幕 min-width=992px

大于1200 大屏幕 min-width=1200px

CSS3

上一篇:css 选择器2


下一篇:HTML基础