CSS 中的background背景属性是前端开发中常用的一个属性,它用于控制元素的背景样式,包括背景颜色、背景图片、背景位置等。
本文将详细探讨 CSS 中的background属性,包括 5 个子属性的用法、作用以及实际应用案例,来让我们一起看看吧。
一、 background-color:用于设置元素的背景颜色。可以使用十六进制值、RGB 值等来指定颜色。例如:
- body {
- background-color: #00ff00; /* 使用十六进制值 */
- /* background-color: rgb(255, 0, 0); 使用RGB值 */
- /*background-color: rgba(255, 0, 0, 0.5); 使用带不透明度的RGB值 */
- }
-
关于颜色的几种写法,可以看这篇文章。html基础:颜色的 5 种表示方法(最全!)
当然,这个背景颜色不止可以作用在 body 标签上,也可以为任何 HTML 元素设置背景颜色,比如 div,p,h1,ul,li,input 等,都可以的。
二、 background-image:用于设置元素的背景图片。它的取值形式主要包括以下 4 种:
咱们今天先说最基础的第 1 种,后面的随着深入学习再说。第 1 种是图片路径,是通过url()可以指定图片的路径,可以是相对路径或绝对路径。例如:
- body {
- background-image: url(./img/bg1.jpg);
- }
-
页面所用图片 bg1.jpg 图片如下:
当然,背景图像不止可以作用在 body 标签上,也可以为任何 HTML 元素设置背景颜色,比如 div,p,h1,ul,li,input 等,都可以。
三、 background-repeat:用于控制背景图片的重复方式。常用的取值包括:
属性值 | 说明 |
---|---|
repeat | 默认值,背景图片在水平和垂直方向上平铺重复显示。 |
repeat-x | 背景图片在水平方向上平铺重复显示。 |
repeat-y | 背景图片在垂直方向上平铺重复显示。 |
no-repeat | 背景图片不重复,只显示一次。 |
例如,默认情况下,背景图片在水平和垂直方向上重复显示:
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8" />
- <meta name="viewport" content="width=device-width, initial-scale=1.0" />
- <title>Document</title>
- <style>
- body {
- background-image: url(./img/bg2.png);
- }
- </style>
- </head>
- <body>
- <h1>hello,world!</h1>
- <h2>这背景,有点奇怪......</h2>
- </body>
- </html>
-
页面所用图片 bg2.png 图片如下:
效果如下:
那其实是不是这个照片往一个水平方向比较好啊,所以,就可以让重复方向变为 repeat-x, 那元素的背景图片就会在水平方向上重复显示了。
- <style>
- body {
- background-image: url(./img/bg2.png);
- background-repeat: repeat-x;
- }
- </style>
-
效果如下:
其他属性你可以自行试试。
四、 background-position:用于控制背景图片的位置。它的取值有三种类型:
属性值 | 说明 |
---|---|
left top | 背景图片在左上角显示。 |
left center | 背景图片在左侧水平居中显示。 |
left bottom | 背景图片在左下角显示。 |
center top | 背景图片在顶部垂直居中显示。 |
center center | 背景图片在水平和垂直方向上都居中显示。 |
center bottom | 背景图片在底部垂直居中显示。 |
right top | 背景图片在右上角显示。 |
right center | 背景图片在右侧水平居中显示。 |
right bottom | 背景图片在右下角显示。 |
例如,将背景图片位置设置在元素的右上角:
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8" />
- <meta name="viewport" content="width=device-width, initial-scale=1.0" />
- <title></title>
- <style>
- body {
- background-image: url(./img/bg3.png);
- background-repeat: no-repeat;
- background-position: right top;
- }
- </style>
- </head>
- <body>
- <h1>hello,world!像素值:指定背景图片位置相对于包含块的像素值。例如,`background-position: 100px 50px;` 表示背景图片距离包含块左侧 100 像素,距离顶部 50 像素。</h1>
-
- ...(把h1和内容复制16行,太长了,这里不写了)
-
- <h1>hello,world!像素值:指定背景图片位置相对于包含块的像素值。例如,`background-position: 100px 50px;` 表示背景图片距离包含块左侧 100 像素,距离顶部 50 像素。</h1>
- <h1>hello,world!像素值:指定背景图片位置相对于包含块的像素值。例如,`background-position: 100px 50px;` 表示背景图片距离包含块左侧 100 像素,距离顶部 50 像素。</h1>
- </body>
- </html>
-
页面所用图片 bg3.png 图片如下:
效果如图所示:
这样设置后,背景图片就会在右上角显示。但是呢,还有一个问题,滚动页面的时候,会发现,图片跟着走了,如图。
能不能滚动的时候,让背景图还固定到头部右上角不动呢?能,这就用到下一个属性了。
五、background-attachment :用于设置背景图片的滚动方式,控制背景图片是否随页面滚动而滚动。
取值有三种:
当然可以,请看下面的表格:
属性值 | 说明 |
---|---|
scroll | 背景图片随页面滚动而滚动,默认值。 |
fixed | 背景图片固定在视口的位置,不随页面滚动而滚动。 |
local | 背景图片随着其所在的容器滚动而滚动,当容器滚动时,背景图片也跟随滚动,而不是整个页面。 |
根据上个案例,只需加上 background-attachment: fixed;属性,代码如下,就不会随着页面的滚动而滚动了。
- <style>
- body {
- background-image: url(./img/bg3.png);
- background-repeat: no-repeat;
- background-position: right top;
- background-attachment: fixed; /* 背景图片固定 */
- }
- </style>
-
效果如图:
这个例子中,背景图片将会固定在浏览器窗口的位置,不会随着页面的滚动而滚动。
这些属性的取值可以根据设计需求灵活使用,可以为网页带来不同的视觉效果和布局。但是每次设置一个背景,需要写5个属性,太多了,能不能一行写完呢?可以。
其实呢,通过巧妙地组合不同的背景属性,我们可以创建出丰富多彩的页面背景效果。
如何混合写呢?就以上一个案例来写吧,增加一个绿色的背景颜色。
- <style>
- body {
- background: #2cecbc url(./img/bg3.png) no-repeat right top fixed;
- }
- </style>
-
效果如图:
当然,这种写法要注意以下 3 点:
这样的设置,也达到了较为简洁而又美观的背景效果。
ok,以上,就是 background 的基础用法了,除了以上 5 个基础子属性,还有background-clip,background-origin,background-size等,这些需要依赖未来的学习,所以后续用到再说。