無.Flac's Blog

無.Flac

CSS3 -2 | 学习记录

CSS
110
2024-03-05

⭐️ 有关CSS3的学习总结



CSS3

> CSS3 是 CSS2 的升级版本,它在 CSS2 的基础上,新增了很多强大的新功能,从而解决一些实际面临的问题。

> CSS3 在未来会按照模块化的方式去发展:

https://www.w3.org/Style/CSS/current-work.html


CSS3 新特性:

> 新增了 更加实用的选择器 ,例如:动态伪类选择器、目标伪类选择器、伪元素选择器等等。

> 新增了 更好的视觉效果 ,例如:圆角、阴影、渐变等。

> 新增了 丰富的背景效果 ,例如:支持多个背景图片,同时新增了若干个背景相关的属性。

> 新增了全新的布局方案 —— 弹性盒子。

> 新增了 Web 字体,可以显示用户电脑上没有安装的字体。

> 增强了颜色,例如: HSL 、 HSLA 、 RGBA 几种新的颜色模式

> 新增 opacity 属性来控制 透明度。

> 增加了 2D 3D 变换,例如:旋转、扭曲、缩放、位移等。

> 增加 动画与过渡效果 ,让效果的变换更具流线性、平滑性。
......


过渡

在不使用 Flash 动画, 或不使用 JavaScript 的情况下,让元素从一种样式,平滑过渡为另一种样式。

> transition-property

作用:定义哪个属性需要过渡,只有在该属性中定义的属性(比如宽、高、颜色等)才会有过渡的效果。

  • 常用值如下

含义

none

不过渡任何属性

all

过渡所有能过渡的属性

具体某个属性名,例如:width、heigth,若有多个以逗号分隔

注意:

  • 不是所有的属性都能过渡,值为数字、或者值能转为数字的属性,都支持过渡,否则不支持过渡。

  • 常见的支持过渡的属性有:颜色、长度值、百分比、z-index、opacity、2D变换属性、3D变换属性、阴影。

> transition-duration

作用:设置过渡的持续时间,即:一个状态过渡到另一个状态耗时多久。

  • 常用值如下

含义

0

没有任何过度时间——默认值

s 或 ms

秒或毫秒

列表:

  • 如果想让所有属性都持续一个时间,那就写一个值。

  • 如果想让每个属性持续不同的时间那就写一个时间的列表。

> transition-delay

作用:指定开始过渡的延迟时间,点位:s 或 ms。

> transition-timeing-fuction

作用:设置过渡的类型。

  • 常用值如下

含义

ease

平滑过渡——默认值

linear

线性过渡

ease-in

慢→块

ease-out

快→慢

ease-in-out

慢→快→慢

step-start

等同于 steps(1,start)

step-end

等同于 steps(1,end)

steps(integer,?)

接受2个参数的步进函数,第1个参数必须为正整数,指定函数的步数,第2个参数取值可以使 start 或 end,指定每一步的值发生变化的时间点。默认参数是 end。

cubic-bezie(x,x,x,x)

特定的贝塞尔曲线类型

在线制作贝塞尔曲线:https://cubic-bezier.com

> transition复合属性

  • 如果设置了一个时间,表示 duration;

  • 如果设置了2个时间,第1个是 duration,第2个是 delay;没有顺序要求。


动画

> 什么是帧?

一段动画,就是一段时间内连续播放 n 个画面,每一张画面,我们管它叫做”帧“。一定时间内连续快速播放若干个帧,就成了人眼中所看到的动画。同样时间内播放的帧数越多,画面看起来越流畅。

> 什么是关键帧?

关键帧是指:在构成一段动画的若干帧中,起到决定作用的帧。

image-ilpg.png

> 动画的基本作用

  • 第一步:定义关键帧(定义动画)

简单定义方式:

/*写法一*/ 
@keyframes 动画名 {
    from {
        /*property1:value1*/
        /*property2:value2*/
	}
	to {
       /*property1:value1*/
	} 
}

完整定义方式:

@keyframes 动画名 { 
	0% {
        /*property1:value1*/
	}
	20% {
	        /*property1:value1*/
	}
	40% {
	        /*property1:value1*/
	}
	60% {
	       /*property1:value1*/
	}
	80% {
	        /*property1:value1*/
	}
	100% {
	        /*property1:value1*/
	} 
}
  • 第二步:给元素应用动画,用到的属性如下:

含义

animation-name

给元素指定具体的动画(具体的关键帧)

animation-duration

设置动画所需时间

animation-delay

设置动画延迟

.box {
	/* 指定动画 */
	animation-name: testKey; 
	/* 设置动画所需时间 */ 
	animation-duration: 5s; 
	/* 设置动画延迟 */ 
	animation-delay: 0.5s;
}

动画的其他属性

> animation-timing-funciton

  • 设置动画的类型,常用值如下

含义

ease

平滑过渡——默认值

linear

线性过渡

ease-in

慢→块

ease-out

快→慢

ease-in-out

慢→快→慢

step-start

等同于 steps(1,start)

step-end

等同于 steps(1,end)

steps(integer,?)

接受2个参数的步进函数,第1个参数必须为正整数,指定函数的步数,第2个参数取值可以使 start 或 end,指定每一步的值发生变化的时间点。默认参数是 end。

cubic-bezie(x,x,x,x)

特定的贝塞尔曲线类型

> animation-iteration-count

  • 指定动画的播放次数,常用值如下

含义

number

动画循环次数

infinite

无限循环

> animation-direction

  • 指定动画方向,常用值如下

含义

normal

正常方向(默认)

reverse

反方向运行

alternate

动画先正常运行在反方向运行,并持续交替运行

alternate-reverse

动画先反运行在正方向运行,并持续交替运行

> animation-fill-mode

  • 设置动画之外的状态

含义

forwards

设置对象状态为动画结束的状态

backwards

设置对象状态为动画开始时的状态

> animation-play-state

  • 设置动画的播放状态,常用值如下

含义

running

运动(默认)

paused

暂停

> 动画的复合属性

只设置一个时间表示 duration,设置两个时间分别是:duration 和 delay,其他属性没有数量和顺序的要求

.inner {
    animation: atguigu 3s 0.5s linear 2 alternate-reverse forwards;
}

备注:animation-paly-state 一般单独使用。


多列布局

> column

作用:专门用于实现类似于报纸的布局。

image-xhme.png

  • 常用属性如下

含义

column-count

指定列数,值是数字

column-width

指定列宽,值是长度

columns

同时指定列宽和列数,复合属性;值没有数量和顺序要求

column-gap

设置列边距,值是长度

column-rule-style

设置列与列之间边框的风格,值与 border-style 一致

column-rule-width

设置列与列之间边框的宽度,值是长度

column-rule-color

设置列与列之间边框的颜色

column-rule

设置列边框,复合属性

column-span

指定是否跨列;值:none、all


伸缩盒模型

> 伸缩盒模型简介

  • 2019 年,W3C提出了一种新的盒子模型 —— Flexible Box (伸缩盒模型,又称:弹性盒子)。

  • 它可以轻松的控制:元素分布方式、元素对齐方式、元素视觉顺序...

  • 截止目前,除了在部分 IE 浏览器不支持,其他浏览器均已全部支持。

  • 伸缩盒模型的出现,逐渐演变出了一套新的布局方案 —— Flex 布局

小贴士:

  • 传统布局是指:基于传统盒状模型,主要靠:display 属性 + position 属性 + float 属性。

  • flex 布局目前在移动端应用比较广泛,因为传统布局不能很好的呈现在移动设备上。

> 伸缩容器与项目

  • 伸缩容器:开启了 flex 的元素,就是:伸缩容器

1、给元素设置:display:flex 或 display:inline-flex ,该元素就变成了伸缩容器。

2、display:inline-flex 很少使用,因为可以给多个伸缩容器的父容器,也设置为伸缩容器。

3、一个元素可以同时是:伸缩容器、伸缩项目。

  • 伸缩项目:伸缩容器所有子元素自动成为了:伸缩项目。

1、仅伸缩容器的子元素成为了伸缩项目,孙子元素、重孙子元素等后代,不是伸缩项目。

2、无论原来是那种元素(块、行内快、行内),一旦成为了伸缩项目,全都会“模块化”。

> 主轴与侧轴

  • 主轴:伸缩项目沿着主轴排列,主轴默认是水平的,默认方向是:从左到右(起点到终点)

  • 侧轴:与主轴垂直的就是侧轴,侧轴默认是垂直的,默认方向是:从上到下(起点到终点)

> flex-direciton 主轴方向

  • 属性名:flex-direciton

  • 常用值如下:

含义

row

主轴方向水平从左到右 —— 默认值

row-reverse

主轴方向水平从右往左

column

主轴方向垂直从上到下

column-reverse

主轴方向垂直从下到上

image-xryl.png

注意:改变了主轴的方向,侧轴方向也随之改变。

> flex-wrap 主轴转换方式

  • 属性名:flex-wrap

  • 常用值如下:

含义

nowrap

默认值,不换行

image-qldq.png

wrap

自动换行,伸缩容器不够时自动换行

image-tmox.png

wrap-reverse

反向换行

image-ftiq.png

> flex-flow 复合属性

  • flex-flow 是一个复合属性,复合了 felx-direction 和 felx-warp 两个属性。值没有顺序要求

flex-flow:row wrap;

> justify-content 主轴的对其方式

  • 属性名:justify-content

  • 常用值如下:

含义

flex-start

主轴起点对齐 —— 默认值

image-kmli.png

flex-end

主轴终点对齐

image-qksu.png

center

居中对齐

image-dbkk.png

space-between

均匀分布,两端对齐(最常用)

image-tutc.png

space-around

均匀分布,两端距离是中间距离的一半

image-nizr.png

space-evenly

均匀分布,两端距离与中间距离一致

image-mpex.png

> 侧轴对齐方式

> align-items 一行的情况
  • 所需属性:align-items

  • 常用值如下:

含义

flex-start

侧轴的起点对齐

image-ktdy.png

flex-end

侧轴的终点对齐

image-ttya.png

center

侧轴的中点对齐

image-bkcx.png

baseline

伸缩项目的第一行文字的基线对齐

image-unhc.png

stretch

如果伸缩项目未设置高度,将沾满整个容器的高度 —— (默认值)

image-zzje.png

> algin-content 多行的情况
  • 所需属性:algin-content

  • 常用值如下:

含义

flex-start

与侧轴的起点对齐

image-hgdz.png

flex-end

与侧轴的终点对齐

image-payj.png

center

与侧轴的中点对齐

image-sfea.png

space-between

与侧轴两端对齐,中间平均分布

image-lqcu.png

space-around

伸缩项目间的距离相等,比距边缘大一倍

image-ydvb.png

space-evenly

在侧轴上完全平分

image-huyc.png

stretch

占满政策侧轴 —— 默认值

image-wclh.png

> flex 实现水平垂直居中

  • 方法一:父容器开始 flex 布局,随后使用 justify-content 和 align-items 实现水平垂直居中

.outer {
    width: 400px;
    height: 400px;
    background-color: #888;
    display: flex;
    justify-content: center;
    align-items: center;
}
.inner {
    width: 100px;
    height: 100px;
    background-color: orange;
}
  • 方法二:父容器开启 flex 布局,随后子元素 margin:auto

.outer {
    width: 400px;
    height: 400px;
    background-color: #888;
    display: flex;
}
.inner {
    width: 100px;
    height: 100px;
    background-color: orange;
    margin: auto;
}

> 伸缩性

>> flex-bais
  • 概念:flex-basis 设置的是主轴方向的基准长度,会让宽度或高度失效

备注:主轴横向:宽度失效;主轴纵向:高度失效

>> flex-grow (伸)
  • 概念:flex-grow 定义伸缩项目的放大比例,默认为 0,即:纵使主轴存在剩余空间,也不拉伸

  • 规则:

1、若所有伸缩项目的 flex-grow 值都为 1,则:它们将等分剩余空间

2、若三个伸缩项目的 flex-grow 值分别为:1、2、3,则:分别瓜分到 1/6、2/6、3/6 的空间

>> flex-shrink (缩)
  • 概念:flex-shrink 定义了项目的压缩比例,默认为 1,即:如果空间不足,该项目将会缩小。

  • 收缩项目的计算,略微负值一点,比如说:

三个收缩项目,宽度分别为:200px、300px、200px,它们的 flex-shrink 值分别为 1、2、3;

若想刚好容下三个项目,需要总宽度为 700px,但目前容器只有 400px,还差300px,

所以每个人都要收缩一下才可以放下,具体收缩的值,这样计算:

1、计算分母:(200*1)+(300*2)+(200*3)= 1400

2、计算比例:
			项目一:(200×1) / 1400 = 比例值1
			项目二:(300×2) / 1400 = 比例值2
			项目三:(200×3) / 1400 = 比例值3
3. 计算最终收缩大小:
    		项目一需要收缩: 比例值1 × 300
   			项目二需要收缩: 比例值2 × 300
    		项目三需要收缩: 比例值3 × 300

> flex复合属性

flex 是复合属性,复合了 flex-grow、flex-shrink、flex-basis 三个属性,默认值为 0 1 auto。

  • 如果写 flex:1 1 auto ,则可简写为 flex:auto

  • 如果写 flex:1 1 0 ,则可简写为:flex:1

  • 如果写 flex:0 0 auto ,则可简写为:flex:none

  • 如果写 flex:0 1 auto ,则可简写为:flex:0 auto —— 即 flex 初始值

> order 项目排序

  • order 属性定义项目的排列顺序。数值越小,排列越靠前,默认为 0

> align-self 单独对齐

  • 通过 align-self 属性,可以单独调整某个伸缩项目的对齐方式

  • 默认值为 auto ,表示继承父元素的 align-items 属性。


响应式布局

> 媒体类型

含义

all

检测所有设备

screen

检测电子平布,包括:电脑屏幕、平板屏幕、手机屏幕等。

print

检测打印机

完整列表请参考: https://developer.mozilla.org/zh-CN/docs/Web/CSS/@media

> 媒体特性

含义

width

检测视口宽度

max-width

检测视口最大宽度

min-width

检测视口最小宽度

height

检测视口高度

max-height

检测视口最大高度

min-height

检测时候最小高度

device-width

检测设备屏幕的宽度

max-device-width

检测设备屏幕的最大宽度

min-device-width

检测设备屏幕的最小宽度

orientation

检测视口的旋转方向(是否横屏)

  • portrait:视口处于纵向,即高度大于等于宽度

  • landscape:视口处于横向,即宽度大于高度

完整列表请参考: https://developer.mozilla.org/zh-CN/docs/Web/CSS/@media

> 运算符

含义

and

并且

, 或 or

not

否定

only

肯定

> 常用阈值

  • 在实际开发中,会将屏幕划分成几个区间,例如:

image-txuq.png

> 结合外部样式的用法

  • 用法一:

<link rel="stylesheet" media="具体的媒体查询" href="mystylesheet.css">
  • 用法二:

@media screen and (max-width:768px) {
    /*CSS-Code;*/
}
@media screen and (min-width:768px) and (max-width:1200px) {
    /*CSS-Code;*/
}

BFC

> 什么是 BFC

  • W3C 上对于 BFC 的定义

原文:

Floats, absolutely positioned elements, block containers (such as inline-blocks, table- cells, and table-captions) that are not block boxes, and block boxes with 'overflow' other than 'visible' (except when that value has been propagated to the viewport) establish new block formatting contexts for their contents.

译文:

浮动、绝对定位元素、不是块盒子的块容器(如 、 table-cells 和 table-captions ),以及 overflow 属性的值除 以外的块盒,将为其内容建立新的块格式化上下文。

  • MSN 上对于 BFC 的定义

块格式化上下文(Block Formatting Context,BFC) 是 Web 页面的可视 CSS 渲染的一部分, 是块盒子的布局过程发生的区域,也是浮动元素与其他元素交互的区域。

  • 更加通俗的描述:

1. BFC 是 Block Formatting Context ( 块级格式上下文 ),可以理解成元素的一个 “特异功能”。

2. 该 “特异功能”,在默认的情况下处于关闭状态;当元素满足了某些条件后,该“特异功能”被激活。

3. 所谓激活“特异功能”,专业点说就是:该元素创建了 BFC (又称:开启了 BFC )。

> 开启了 BFC 能解决什么问题

  • 元素开启 BFC 后,其子元素不会再产生 margin 塌陷问题。

  • 元素开启 BFC 后,自己不会被其他浮动元素所覆盖。

  • 元素开启 BFC 后,就算其子元素浮动,元素自身高度也不会塌陷。

> 如何开启 BFC

  • 根元素

  • 浮动元素

  • 绝对定位、固定定位元素

  • 行内块元素

  • 表格单元格:table、thead、tbody、tfoot、th、td、tr、caption

  • overflow 的值 visible 的块元素

  • 伸缩项目

  • 多列容器

  • column-span 为 all 的元素(即使该元素没有包裹在多列容器中)

  • display 的值,设置为 flow-root

  • 5