HTML + CSS 连载 | 24 - CSS 设置背景

一、设置背景-background-image

在开发中,为了让网页更加美观,我们经常会设置各种各样的背景,比如

background-image 属性用于设置元素的背景图片,这个背景图片会盖在 background-color 上面。

新建一个 HTML 页面,设置 background-image,具体代码如下:

HTML 复制代码
<!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>
    .box {
      width: 1000px;
      height: 1000px;
      background-color: #f00;

      /*设置背景图片*/
      background-image: url(../images/2970184.png);
    }
  </style>
</head>
<body>
  <div class="box"></div>
</body>
</html>

在浏览器中打开该 HTML 页面,效果如下:

可以看到 background-image 背景图片是盖在 background-color 背景颜色上面的,background-image 也支持设置多张图片,多张图片之间使用逗号隔开,并且显示的顺序为设置的顺序,第一个设置的图片会在最上面,其他一次叠加在下面。

HTML 复制代码
<!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>
    .box {
      width: 1000px;
      height: 1000px;
      background-color: #f00;

      /*设置背景图片*/
      background-image: url(../images/2970184.png);
      /*设置不重复图片*/
      background-repeat: no-repeat;
    }
  </style>
</head>
<body>
  <div class="box"></div>
</body>
</html>

在浏览器中打开 HTML 页面,效果如下:

需要注意的是如果设置了背景图片后,元素没有具体的宽高,背景图片是不会显示出来的。

CSS 复制代码
.box {
  /*width: 1000px;
  height: 1000px;*/
  background-color: #f00;

  /*设置背景图片*/
  background-image: url(../images/2970184.png);
  /*设置不重复图片*/
  background-repeat: no-repeat;
}

注释掉 CSS 设置的宽高之后,图片不再显示出来。

二、设置背景-background-repeat

前面的代码中如果设置了元素的宽高是大于图片的情况下,图片会出现重复或者平铺的情况,这种情况可以使用 background-repeat 属性来控制。

background-repeat 属性用于设置背景图片是否要平铺,常见的设置的值有:

  • repeat:平铺,在水平和垂直方向上平铺
  • no-repeat:不平铺
  • repeat-x:只在水平方向上平铺
  • repeat-y:只在处置方向上平铺

background-repeat 属性的默认值是 repeat,会在水平和垂直方向上平铺,新建 HTML 页面,代码如下:

HTML 复制代码
<!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>
    .box {
      width: 800px;
      height: 800px;

      background-image: url(../images/1228984.png);
      
    }
  </style>
</head>
<body>
  <div class="box"></div>
</body>
</html>

在浏览器中打开页面,效果如下:

我们可以设置在水平方向上平铺,修改 CSS 代码为如下形式:

CSS 复制代码
    .box {
      width: 800px;
      height: 800px;

      background-image: url(../images/1228984.png);
      background-repeat: repeat-x;
    }

也可以设置只在垂直方向上平铺,修改 CSS 代码为如下形式:

CSS 复制代码
    .box {
      width: 800px;
      height: 800px;

      background-image: url(../images/1228984.png);
      background-repeat: repeat-y;
    }

当然我们也可以设置不平铺,使用 no-repeat 属性值即可,修改 CSS 代码为如下形式:

CSS 复制代码
    .box {
      width: 800px;
      height: 800px;

      background-image: url(../images/1228984.png);
      background-repeat: no-repeat;
    }

利用平铺的特性,我们可以实现这样一个由多个相同图片构成的背景。

HTML 复制代码
<!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>
    .box {
      width: 600px;
      height: 600px;
      background-color: #f00;

      /*设置背景图片,默认是会在水平和垂直方向上平铺,无须任何设置*/
      background-image: url(../images/wall.png);
    }
  </style>
</head>
<body>
  <div class="box"></div>
</body>
</html>

在浏览器中打开该 HTML 页面,效果如下:

三、设置背景-background-size

background-size 可以设置背景图片的大小,包含以下几个值:

  • auto:默认值,以背景图片本身大小显示
  • cover:缩放背景图,以完全覆盖铺满元素,可能背景图片部分看不见
  • contain:缩放背景图,宽度或者高度铺满元素,但是图片保持宽高比
  • <percentage>:百分比,相对于背景区
  • <length>:具体的长度,比如 100px
HTML 复制代码
<!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>
    .box {
      width: 600px;
      height: 600px;
      background-color: #f00;

      /*设置背景图片及平铺方式*/
      background-image: url(../images/1228984.png);
      background-repeat: no-repeat;
    }
  </style>
</head>
<body>
  <div class="box"></div>
</body>
</html>

设置背景尺寸之前的效果如下:

通过 background-size 设置背景属性:

CSS 复制代码
.box {
  width: 600px;
  height: 600px;
  background-color: #f00;

  /*设置背景图片及平铺方式*/
  background-image: url(../images/1228984.png);
  background-repeat: no-repeat;

  /*设置图片尺寸*/
  background-size: contain;
}

设置为 contain,会把某一边拉伸,具体效果如下:

修改 background-size 属性:

CSS 复制代码
.box {
  width: 600px;
  height: 600px;
  background-color: #f00;

  /*设置背景图片及平铺方式*/
  background-image: url(../images/1228984.png);
  background-repeat: no-repeat;

  /*设置图片尺寸*/
  background-size: cover;
}

设置为 conver,图片会保持原来的宽高比,超出的部分会被隐藏,具体效果如下:

除了固定值之外,也可以设置百分比:

CSS 复制代码
    .box {
      width: 600px;
      height: 600px;
      background-color: #f00;

      /*设置背景图片及平铺方式*/
      background-image: url(../images/1228984.png);
      background-repeat: no-repeat;

      /*设置图片尺寸*/
      background-size: 100% 100%;
    }

在浏览器中打开 HTML 页面,具体效果如下:

当然也可以设置具体的值:

CSS 复制代码
.box {
  width: 600px;
  height: 600px;
  background-color: #f00;

  /*设置背景图片及平铺方式*/
  background-image: url(../images/1228984.png);
  background-repeat: no-repeat;

  /*设置图片尺寸*/
  background-size: 100px 100px;
}

在浏览器中打开 HTML 页面,具体效果如下:

相关推荐
cnxy1883 分钟前
Python Web开发新时代:FastAPI vs Django性能对比
前端·python·fastapi
神仙姐姐QAQ4 分钟前
vue3更改.el-dialog__header样式不生效
前端·javascript·vue.js
脾气有点小暴4 分钟前
uniapp真机调试无法连接
前端·uni-app
AI_56786 分钟前
Vue.js 深度开发指南:从数据绑定到状态管理的最佳实践
前端·javascript·vue.js
Irene19916 分钟前
Sass常用语法总结
前端·sass
程序员爱钓鱼7 分钟前
Node.js 博客系统实战(一):项目需求分析
前端·后端·node.js
阿星AI工作室8 分钟前
魔改豆包输入法变电脑版,立即拥有千元AI语音输入法typeless平替
前端·人工智能
前端-文龙刚9 分钟前
浅记Vue3中 ref 和 reactive 是两种主要的响应式数据声明方式,它们有以下主要区别
前端·javascript·vue.js
小先生81211 分钟前
关于vue-element-plus-admin的mini分支踩坑集锦
前端·vue.js·前端框架·c#
hhcccchh11 分钟前
学习vue第十天 V-Model学习指南:双向绑定的魔法师
前端·vue.js·学习