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

一、设置背景-background-position

background-position 用于设置背景图片在水平、垂直方向上的具体位置,可以设置具体的值,如 20px 30px,水平和垂直方向上还可以设置 left\top、center、right\bottom 等值,如果只设置了一个方向,另一个方向默认是 center。

设置图片的 background-position 为具体的方位,代码如下:

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/selenium_python.png);
      background-repeat: no-repeat;

      /*设置图片位置*/
      background-position: right bottom;
    }
  </style>
</head>
<body>
  <div class="box"></div>
</body>
</html>

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

也可以设置 center 方位:

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

  /*设置背景图片*/
  background-image: url(../images/selenium_python.png);
  background-repeat: no-repeat;

  /*设置图片位置*/
  background-position: center center;
}

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

二、设置背景-background-attchment

background-attachment 属性决定背景图片的位置是在视口内固定或者随着包含它的区块滚动;该属性可以设置以下三个值:

  • scroll:表示背景相对于元素本身固定,而不是随着它的内容移动
  • local:表示背景相对于元素的内容固定,如果一个元素拥有滚动机制,背景将会随着元素的内容滚动
  • fixed:背景相对于视口固定,即使一个元素用于滚动机制,背景也不会随着元素的内容滚动
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: 150px;
      height: 200px;
      overflow: scroll;
      background-color: #f00;
      background-image: url(../images/selenium.webp);
    }
  </style>
</head>
<body>
  <div class="box">
    MySQL 是一个开放源码的小型关联式数据库管理系统,开发者为瑞典 MySQL AB 公司。目前 MySQL 被广泛地应用在 Internet 上的中小型网站中。由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了 MySQL 作为网站数据库。
  </div>
</body>
</html>

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

当滚动文字的时候,图片并没有随着文字一起滚动,通过设置 background-attchment 为 local 就可以让背景图片随着文字一起滚动;

CSS 复制代码
.box {
  width: 150px;
  height: 200px;
  overflow: scroll;
  background-color: #f00;
  background-image: url(../images/selenium.webp);

  background-attachment: local;
}

刷新页面,滚动文字可以看到图片随着一起滚动:

给 HTML 页面增加内容,使视口出现滚动条,并设置 background-attchment 的值为 fixed,具体 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: 150px;
      height: 500px;
      overflow: scroll;
      background-color: #f00;
      background-image: url(../images/selenium.webp);

      background-attachment: fixed;
    }
  </style>
</head>
<body>
  <div class="box">
    MySQL 是一个开放源码的小型关联式数据库管理系统,开发者为瑞典 MySQL AB 公司。目前 MySQL 被广泛地应用在 Internet 上的中小型网站中。由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了 MySQL 作为网站数据库。
    MySQL 是一个开放源码的小型关联式数据库管理系统,开发者为瑞典 MySQL AB 公司。目前 MySQL 被广泛地应用在 Internet 上的中小型网站中。由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了 MySQL 作为网站数据库。
  </div>
  <br><br><br><br><br><br><br><br>
  <br><br><br><br><br><br><br><br>
  <br><br><br><br><br><br><br><br>
  <br><br><br><br><br><br><br><br>
  <br><br><br><br><br><br><br><br>
</body>
</html>

刷新页面,并滚动视图的滚动条,可以看到背景图片是不动的;

background 属性

background 属性是一系列背景相关属性的简写,常用格式如下:

需要注意的是:

  • background-size 可以省略,如果不省略,background-size 必须紧跟在 background-position 的后面。
  • 其他属性也都可以省略,而且顺序任意。

三、backgournd-image 与 img 的对比

利用 background-image 和 img 元素都能够实现显示图片的需求,那么它们之间有什么区别?

img background-image
性质 HTML 元素 CSS 样式
图片是否占用空间
浏览器右键是否可以直接查看地址
支持 CSS Sprite
更有可能搜索引擎收录 是(结合 alt 属性)

img 元素作为 HTML 内容的重要组成部分,比如广告图片、LOGO 图片、文章配图以及产品图片等;而 background-imge 则可有可无,有可以让网页更加美观,没有也不影响用户获取完整的网页信息内容。

相关推荐
JELEE.2 分钟前
Django登录注册完整代码(图片、邮箱验证、加密)
前端·javascript·后端·python·django·bootstrap·jquery
TeleostNaCl2 小时前
解决 Chrome 无法访问网页但无痕模式下可以访问该网页 的问题
前端·网络·chrome·windows·经验分享
charlie1145141912 小时前
CSS笔记4:CSS:列表、边框、表格、背景、鼠标与常用长度单位
css·笔记·学习·css3·教程
前端大卫4 小时前
为什么 React 中的 key 不能用索引?
前端
你的人类朋友4 小时前
【Node】手动归还主线程控制权:解决 Node.js 阻塞的一个思路
前端·后端·node.js
小李小李不讲道理5 小时前
「Ant Design 组件库探索」五:Tabs组件
前端·react.js·ant design
毕设十刻5 小时前
基于Vue的学分预警系统98k51(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
mapbar_front6 小时前
在职场生存中如何做个不好惹的人
前端
牧杉-惊蛰6 小时前
纯flex布局来写瀑布流
前端·javascript·css
一袋米扛几楼988 小时前
【软件安全】什么是XSS(Cross-Site Scripting,跨站脚本)?
前端·安全·xss