前言

平时在用三方UI库的时候,那爽🉐️不要不要的,但是作为一个前端开发者,如果连基本的界面都不能画好的话,又怎么能够胜任得了后续复杂不断的业务变动以及页面的交互呢。
之前从来没有考虑过这个问题,认为不懂的内容,只需要简单的度娘就可以了,实际上,更重要的是要关注于基础,凡事多问几个为什么。
本文从元素的背景属性:background来进行诠释,向自己解析其中是如何将背景给发挥🉐️淋漓尽致的。

开局先上一幅图,了解一个整体的概况:

CSS中的Background属性

background-image

设置元素的背景图片

描述 描述
取值
继承性 false
动画性 false

<image>中的取值范围为:[<uri>|<linear-gradient>|<repeating-linear-gradient>|<radial-gradient>|<repeating-radial-gradient>]

⚠️ 这里🈶️一个点需要注意的是:background-image允许接收多个不同的参数,代表这不同的背景,同时需要配合background-position来控制不同的背景元素。如下代码所示:

1
2
3
4
5
6
7
8
  <style>
#example{
background-image: url(img_flwr.gif), url(paper.gif);
background-position: right bottom, left top;
background-repeat: no-repeat, repeat;
padding: 15px;
}
</style>

渐变背景

渐变指从一个颜色到另一个颜色的平滑过度,比如从黑色过度到白色的渐变,从黑色开始,经过一系列不同深度的灰白色之后,最终变为白色,渐变的平缓或者骤变程度取决于渐变的作用空间(即元素大小),
比如在100像素的长度内由黑色渐变为白色,渐变累进的过程中每次变白1%。
首先”祭出”渐变机制的一个原理介绍图:

渐变梯形的原理

⚠️ 渐变是图像!渐变是图像!渐变是图像!!!

1. linear-gradient

线性渐变,指的是沿线性向量填充得到的渐变,这个向量称之为梯度线(gradient line),也就是这个属性命名的由来。

语法:

linear-gradient(
[[ <angle> | to <side-or-quadrant> ], ]? [ <color-stop> [, <color-hint>] ], # <color-stop>
);

上述的属性名词解释:

  1. angle: 代表梯度线于水平线的角度,默认是90deg,代表从上往下,如果是负数则代表从下往上,一般使用deg作为单位;
  2. to side-or-quadrant: 代表梯度线指向的象限,这里不一定代表是指向所在象限的正中间;
  3. color-stop: 定位色标,代表每个渐变区间的结束颜色值,这里渐变可以是有多段区间范围的,因此需要有对应的色标;
    • 完整句法: <color> [ <length> | <percentage> ]?
    • 句法解释:在每个颜色值之后可以提供一个位置值,这样子就可以将常规情况下的均匀累进的色标变换调整为自定义的方式
  4. color-hint: 中色点,代表一段渐变区间的中间位置,默认是正中间

对应于如下的实例:

1
2
3
4
5
6
7
8
9
10
11
12
13
.ext { background-image: linear-gradient(purple, gold); }
.ext { background-image: linear-gradient(90deg, purple, gold); }
.ext { background-image: linear-gradient(to left, purple, gold); }
.ext { background-image: linear-gradient(-135deg, purple, gold, navy); }
.ext { background-image: linear-gradient(to bottom left, purple, gold, navy); }
.ext {
// 这里代表从左往右,先是红色,渐变到25px为橙色,然后渐变到50px为黄色,然后渐变到75px为蓝色,然后渐变到100px为绿色,这里的像素值也可以替换为百分比
background-image: linear-gradient(90deg, red, orange 25px, yellow 50px, blue 75px, green 100px);
}
/* 针对color-stop可以有以下的一个应用,形成分段式的背景 */
.ext{
background-image: linear-gradient(90deg, red 0%, red 25%, orange 25%, orange 50%, yellow 50%, yellow 75%, blue 75%, blue 100%);
}

以下是针对上述的分段式的效果:

linear-gradient分段式效果

2. radial-gradient

径向渐变的方式来创建图像,径向渐变由中心点来定义,为了创建径向渐变的效果,我们必须设置好两个终止色

语法:

background-image: radial-gradient(shapre, size at position, start-color, …, last-color);

上述的属性名词解释:

  1. shape: 确定圆的类型:
    • ellipse(默认):指定椭圆形的径向渐变;
    • circle: 指定原型的径向渐变;
  2. size: 定义渐变的大小,可以是以下的值:
    • farthest-corner(默认): 指定径向渐变的半径长度为从圆心到离圆心最远的角;
    • closest-side: 指定径向渐变的半径长度为从圆心到离圆心最近的边;
    • closest-corner: 指定径向渐变的半径长度为从原心到离圆心最近的角;
    • farthest-side: 指定径向的半径长度为从圆心到离圆心最远的边。
  3. position: 定义渐变的位置
    • center(默认): 设置中间为径向渐变圆心的纵坐标值;
    • top: 设置顶部为径向渐变圆心的纵坐标值;
    • bottom: 设置底部为径向渐变圆心的纵坐标值
    • start-color, …, last-color: 用于指定渐变圆心的纵坐标值
3. repeating-linear-gradient与repeating-radial-gradient

用于创建重复线性渐变的背景图像

background-image多张图片效果

✨ 由此可见,我们通过对应在顺序位置上进行属性的配置,可以达到针对一个元素进行多个背景的同时配置。

background-position

指定背景图片的具体位置

描述 描述
取值 <position>
继承性 false
动画性 false

<postion> 中的取值范围为:
[left|center|right|top|bottom] | [<percentage>] | [<length>] && [left|center|right|top|bottom] | [<percentage>] | [<length>]
也就是它接收两个参数,分辨指定其x位置还有y位置

✨ 当它设置为center值的时候,代表着背景图片的中心点与元素的中心点重合

✨ 当设置为负数的数值的时候,代表将这个背景图片分布在元素之外

⚠️ background-position是可以接收4个参数的,代表的意思是从对应的位置往对应方向上偏移多少个像素还是多少百分比,如下所示:

1
2
3
4
5
  <style>
.p{
background-position: right 33% bottom 30px;
}
</style>

👆 这行代码表示将p的背景图片放置在距离右边33%、距离底部30px的位置

background-origin

有了👆的background-position,我们可以改变放置在元素背景中的图像的位置,但是,如果不想让位置相对元素内边距的外边界(默认行为)来计算呢?
我们可以使用background-origin属性来设置,background-origin属性确定计算源图像的位置时以什么的边界作为基准

描述 描述
取值 border-box / padding-box / content-box
初始值 padding-box
继承性 false
动画性 false
取值 描述
border-box 背景图像从边框处开始绘制(计算)
padding-box 背景图像从padding处开始绘制(计算)
content-box 背景图像从内容处开始绘制(计算)

比如有以下的一个代码以及对应的执行效果:
background-origin属性对应效果

background-clip

裁剪背景,背景会填满元素的整个背景区域,一直以来,背景一直延伸到边框的外边界,而css中有一个属性能够控制背景延伸到何处。

描述 描述
取值 border-box / padding-box / content-box
初始值 border-box
继承性 false
动画性 false

而对于该值的不同属性描述如下:

取值 描述
border-box 默认值,背景绘制在边框内
padding-box 背景绘制在padding边框内
content-box 背景绘制在内容边框内

比如有以下的一个代码以及对应的执行效果:
background-clip的使用对比

background-repeat

设置如何平铺对象的background-image属性,默认情况下,会从垂直和水平方向上平铺

描述 描述
取值 repeat / repeat-x / repeat-y / no-repeat / space / round
初始值 repeat
继承性 false
动画性 false

取值描述如下:

取值 描述
repeat 横竖方向都平铺
repeat-x 横方向上平铺
repeat-y 竖直方向上平铺
no-repeat 不平铺,仅有一图像背景
space 类似于flex布局中的justify-content属性,根据图像大小来设置屏幕数量,并采用类似于space-between的分布效果
round 如果背景区域的一边到对边之间无法重复整数次,那么图像将被缩小或者放大,使其刚好重复整数次

✨ 与其他属性background-position的配合,如果background-position被设置为’center’的话,那么这个背景图像将从中间的位置向两侧开始平铺,如果只设置单个方向上进行平铺的话,那么对应的只会在对应方向居中的位置进行平铺的

background-attachment

控制背景固定在元素的某个位置还是随着元素一起发生滚动,当元素出现滚动条的时候。
使用background-attachment可以将源图像声明为固定在视区中,从而免受滚动的影响

描述 描述
取值 scroll / fixed / local
初始值 scroll
继承性 false
动画性 false

取值描述如下:

取值 描述
scroll 默认值随着页面滚动而滚动
fixed 固定在元素的背景位置,不随着内容滚动而滚动
local 背景图片会随着元素内容的滚动而滚动

对应的对比效果如下:
background-attachment属性效果对比

background-size

控制背景图像的尺寸展示,我们可以控制背景图像的大小展示,已符合节点元素的宽高

描述 描述
取值 length / percentage / auto / cover / contain
初始值 auto
继承性 false
动画性 false

取值描述如下:

取值 描述
length 设置背景图的宽度和高度,第一个值设置宽度,第二个值设置高度,如果只给一个值,则第二是auto
percentage 将计算相对于背景定位区域的百分比,如果只给一个值的话,则另外一个为auto
cover 保持图像的宽高比并将图像缩放成完全覆盖背景定位区域的最小大小
contain 保持图像的宽高比并将图像缩放成适合背景定位区域的最大大小

以下是对应的执行效果:
background-size的使用效果

⚠️ 这里有一点需要关注的是:percentage类型的值,它的一个参照物是由background-origin所定义的区域来作为决定的,按照参照物的百分比来换算的!

关于auto值的计算规则有以下三个步骤:

  1. 如果只设置了一个值为非auto,且图像包含有尺寸信息,那么另外一边则会自适应按照比例来展示;
  2. 如果第一步失败了,图像则按照原来的尺寸展示;
  3. 解析为100%。

覆盖与容纳:
background-size的执行结果