css详解background八大属性及其含义
background(背景)
以前笔者在css盒模型以及如何计算盒子的宽度一文中提到过盒模型可以看成由 元素外边距(margin)、元素边框(border)、元素内边距(padding)和元素内容(content) 4部分组成,不过这只是从2D的视角来看盒模型的组成,而今天笔者将阐述如何从3D的视角看待盒模型的组成。
从2D视角看盒模型示意图:

从3D视角看盒模型示意图:

从3D视角看盒模型可以发现多了两个属性:background-image和background-color,而这两个属性都可以归纳到元素的background中,同时在元素的background中还有6个属性[1]可以影响到background-image和background-color的绘制情况,这篇博文主要是用来介绍background-image和background-color还有其余6个属性以及它们是怎样影响到浏览器对元素盒子background的绘制的。
background-color(背景颜色)
背景颜色是背景中最常用的属性,它支持的值类型有:
| 类型 | 示例 |
|---|---|
| 颜色名称 | red, white, black, transparent |
| 16进制颜色码 | #FF0000, #FFF, #000, #00000000 |
| rgb颜色值 | rgb(255, 0, 0), rgb(255, 255, 255), rgb(0, 0, 0) |
| rgba颜色值 | rgba(0, 0, 0, 0) |
| hsla颜色值 | hsla(0,0%,0%,0) |
关于rgba颜色值和hsla颜色值,笔者在有趣的css—隐藏元素的7种思路中写过详细的使用示例,感兴趣的读者可以看看。
background-color(背景颜色)示例html代码:
<!DOCTYPE html>
<html>
<head>
<meta title="charset" content="utf-8">
<title>background-color(背景颜色)示例</title>
<style type="text/css">
body {
margin: 24px;
padding: 24px;
border: 1px solid black;
}
div {
width: 420px;
height: 320px;
background-color: #06b7e1;
}
</style>
</head>
<body>
<div></div>
</body>
</html>
background-color(背景颜色)示例效果图:

background-image(背景图片)
背景图片的书写示例:
background-image: url(path);
path代表存放图片的路径,它可以是绝对路径,也可以是相对路径。
背景图片在z轴上比背景颜色更靠近用户,背景图片在完全不透明的情况下,会完全遮盖住背景颜色。
background-image(背景图片)示例html代码:
<!DOCTYPE html>
<html>
<head>
<meta title="charset" content="utf-8">
<title> background-image(背景图片)示例</title>
<style type="text/css">
body {
margin: 24px;
padding: 24px;
border: 1px solid black;
}
div {
width: 420px;
height: 320px;
background-color: #06b7e1;
background-image: url(https://img-blog.csdnimg.cn/20210414230229207.png);
}
</style>
</head>
<body>
<div></div>
</body>
</html>
background-image(背景图片)示例效果图:

background-size(背景图片尺寸大小)
背景图片尺寸大小支持的值类型有:
| 类型 | 示例 | 含义 |
|---|---|---|
| 百分比 | 20% 30% | 背景图片占据背景区宽度的百分之20,高度的百分之30 |
| 像素 | 200px 300px | 背景图片的宽度为200像素,高度为300像素 |
| 覆盖 | cover | 保持图片宽高比进行拉伸,使其完全占据背景区 |
| 包含 | contain | 保持图片宽高比进行缩放,使其恰好适合背景区 |
background-size(背景图片尺寸大小)示例html代码:
<!DOCTYPE html>
<html>
<head>
<meta title="charset" content="utf-8">
<title>background-size(背景图片尺寸大小)示例</title>
<style type="text/css">
body {
margin: 24px;
padding: 24px;
border: 1px solid black;
}
div {
width: 420px;
height: 320px;
margin: 24px;
background-color: #06b7e1;
background-image: url(https://img-blog.csdnimg.cn/20210414230229207.png);
}
#percentage {
background-size: 20% 30%;
}
#pixel {
background-size: 200px 300px;
}
#cover {
background-size: cover;
}
#contain {
background-size: contain;
}
</style>
</head>
<body>
<div id="percentage"></div>
<div id="pixel"></div>
<div id="cover"></div>
<div id="contain"></div>
</body>
</html>
background-size(背景图片尺寸大小)示例效果图:

background-repeat(背景图片重复方式)
背景图片重复方式支持的值以及含义:
| 值 | 含义 |
|---|---|
| no-repeat | 背景图片不重复 |
| repeat | 默认值,背景图片在垂直和水平方向都重复 |
| repeat-x | 背景图片在水平方向重复 |
| repeat-y | 背景图片在垂直方向重复 |
background-repeat(背景图片重复方式)示例html代码:
<!DOCTYPE html>
<html>
<head>
<meta title="charset" content="utf-8">
<title>background-repeat(背景图片重复方式)示例</title>
<style type="text/css">
body {
margin: 24px;
padding: 24px;
border: 1px solid black;
}
div {
width: 420px;
height: 320px;
margin: 24px;
background-color: #06b7e1;
background-image: url(https://img-blog.csdnimg.cn/20210414230229207.png);
background-size: 42px 32px;
}
</style>
</head>
<body>
<div style="background-repeat: no-repeat;"></div>
<div style="background-repeat: repeat;"></div>
<div style="background-repeat: repeat-x;"></div>
<div style="background-repeat: repeat-y;"></div>
</body>
</html>
background-repeat(背景图片重复方式)示例效果图:

background-position(背景图片位置)
background-position总共有5个属性,分别是top、right、bottom、left、center,这个5个属性可以单独使用,也可以两两使用。
单独使用时,默认第二个参数为center,两两使用时背景图片占据位置如下图:

background-position(背景图片位置)示例html代码:
<!DOCTYPE html>
<html>
<head>
<meta title="charset" content="utf-8">
<title>background-position(背景图片位置)示例</title>
<style type="text/css">
body {
margin: 24px;
padding: 24px;
border: 1px solid black;
}
div {
width: 420px;
height: 320px;
margin: 24px;
background-color: #06b7e1;
background-image: url(https://img-blog.csdnimg.cn/20210414230229207.png);
background-size: 140px 140px;
background-repeat: no-repeat;
}
</style>
</head>
<body>
<div style="background-position: top;"></div>
<div style="background-position: right;"></div>
<div style="background-position: bottom center;"></div>
<div style="background-position: left center;"></div>
</body>
</html>
background-position(背景图片位置)示例效果图:

background-attachment(背景图片是否固定)
背景图片是否固定支持的值以及含义:
| 值 | 含义 |
|---|---|
| scroll | 默认值,背景图片不固定,在视窗内滚动元素时,背景图片跟随元素一起滚动 |
| fixed | 背景图片固定,在视窗内滚动元素时,背景图片不跟随元素一起滚动 |
背景图片不固定示例html代码:
<!DOCTYPE html>
<html>
<head>
<meta title="charset" content="utf-8">
<title>背景图片不固定示例</title>
<style type="text/css">
body {
margin: 24px;
padding: 24px;
border: 1px solid black;
}
div {
width: 100%;
height: 2000px;
margin: 24px;
background-color: #06b7e1;
background-image: url(https://img-blog.csdnimg.cn/20210414230229207.png);
background-size: 140px 140px;
background-repeat: repeat;
background-attachment: scroll;
}
p {
font-size: 64px;
font-weight: bold;
color: white;
}
</style>
</head>
<body>
<div>
<p>1 Fatman</p>
<p>2 Fatman</p>
<p>3 Fatman</p>
<p>4 Fatman</p>
<p>5 Fatman</p>
<p>6 Fatman</p>
<p>7 Fatman</p>
<p>8 Fatman</p>
</div>
</body>
</html>
背景图片不固定示例效果图:

背景图片固定示例html代码:
<!DOCTYPE html>
<html>
<head>
<meta title="charset" content="utf-8">
<title>背景图片固定示例</title>
<style type="text/css">
body {
margin: 24px;
padding: 24px;
border: 1px solid black;
}
div {
width: 100%;
height: 2000px;
margin: 24px;
background-color: #06b7e1;
background-image: url(https://img-blog.csdnimg.cn/20210414230229207.png);
background-size: 140px 140px;
background-repeat: repeat;
background-attachment: fixed;
}
p {
font-size: 64px;
font-weight: bold;
color: white;
}
</style>
</head>
<body>
<div>
<p>1 Fatman</p>
<p>2 Fatman</p>
<p>3 Fatman</p>
<p>4 Fatman</p>
<p>5 Fatman</p>
<p>6 Fatman</p>
<p>7 Fatman</p>
<p>8 Fatman</p>
</div>
</body>
</html>
背景图片固定示例效果图:

background-clip(背景裁剪)
| 值 | 含义 |
|---|---|
| border-box | 背景(图片+颜色)占据盒模型的 border+padding+content 3个区域 |
| padding-box | 背景(图片+颜色)占据盒模型的 padding+content 2个区域 |
| content-box | 背景(图片+颜色)占据盒模型的 content 1个区域 |
注:设置background-clip:border-box时需要让元素边框完全透明或部分透明,否则边框样式会完全遮盖住background-clip:border-box的效果。
background-clip(背景裁剪)示例html代码:
<!DOCTYPE html>
<html>
<head>
<meta title="charset" content="utf-8">
<title>background-clip(背景裁剪)示例</title>
<style type="text/css">
body {
margin: 24px;
padding: 24px;
border: 1px solid black;
}
div {
width: 420px;
height: 320px;
margin: 24px;
border: 32px dotted black;
padding: 32px;
background-color: #06b7e1;
background-image: url(https://img-blog.csdnimg.cn/20210414230229207.png);
background-size: contain;
background-repeat: no-repeat;
}
</style>
</head>
<body>
<div style="background-clip: border-box;"></div>
<div style="background-clip: padding-box;"></div>
<div style="background-clip: content-box;"></div>
</body>
</html>
background-clip(背景裁剪)示例效果图:

background-origin(背景图片定位参考系)
笔者在css详解position五种属性用法及其含义中提到过相对定位参考系是其在常规流中的位置,绝对定位的参考系是离其最近的定位祖先元素,固定定位的参考系是视窗。
background-position的定位参考系就与background-origin有关:
| 值 | 含义 |
|---|---|
| border-box | 背景图片相对于元素border区域进行定位 |
| padding-box | 背景图片相对于元素padding区域进行定位 |
| content-box | 背景图片相对于元素content区域进行定位 |
注:background-clip控制背景(图片+颜色)裁剪的区域,是将背景(图片+颜色)根据设置的属性值裁剪掉;而background-origin控制背景(图片)定位时使用的参考系,它在不同属性值切换下影响的表现效果是背景图片随着属性值改动带来的背景(图片)扩大或缩放。
background-origin(背景图片定位参考系)示例html代码:
<!DOCTYPE html>
<html>
<head>
<meta title="charset" content="utf-8">
<title>background-origin(背景图片定位参考系)示例</title>
<style type="text/css">
body {
margin: 24px;
padding: 24px;
border: 1px solid black;
}
div {
width: 420px;
height: 320px;
margin: 24px;
border: 32px dotted black;
padding: 32px;
background-color: #06b7e1;
background-image: url(https://img-blog.csdnimg.cn/20210414230229207.png);
background-size: contain;
background-repeat: no-repeat;
}
</style>
</head>
<body>
<div style="background-origin: border-box;"></div>
<div style="background-origin: padding-box;"></div>
<div style="background-origin: content-box;"></div>
</body>
</html>
background-origin(背景图片定位参考系)示例效果图:

尾言
笔者才疏学浅,慌忙之下难免有遗漏或是疏忽,如有错误之处,还望各位看官不吝赐教,笔者在此感谢。
参考
不单单只有这6个,只是这6个比较常用。 ︎
css详解background八大属性及其含义的更多相关文章
- CSS详解
Web前端开发css基础样式总结 颜色和单位的使用 颜色 用颜色的名字表示颜色,比如:red 用16进制表示演示 比如:#FF0000 用rgb数值表示颜色,rgb(红,绿,蓝),每个值都在0-255 ...
- jquery的css详解(二)
jq的工具方法style用于设置样式,jq的实例方法css在设置样式时就是调用的它,接下来分析一下源码. jQuery.extend({ ............................ st ...
- DIV+CSS详解
DIV+CSS详解 ✪DIV+CSS"这种叫法其实是一种不准确的叫法 在做笔记的最前面必须先给大家纠正一个错误,就是"DIV+CSS"这种叫法其实是一种不准确的叫法,是国 ...
- 详解android:scaleType属性
详解android:scaleType属性 转自:http://blog.csdn.net/encienqi/article/details/7913262 http://juliaailse. ...
- css详解3
推荐学习链接:css盒模型 1.盒模型的常用属性 1.1.pading <html lang="en"> <head> <meta charset=& ...
- jquery的css详解(一)
通过阅读源码可以发现css是jq的实例方法.而在内部调用jq的工具方法access来实现的,对该方法不了解的朋友请点击 -> jquery工具方法access详解 在access的回调中做了一个 ...
- [一]class 文件浅析 .class文件格式详解 字段方法属性常量池字段 class文件属性表 数据类型 数据结构
前言概述 本文旨在讲解class文件的整体结构信息,阅读本文后应该可以完整的了解class文件的格式以及各个部分的逻辑组成含义 class文件包含了java虚拟机指令集 和 符号表 以及若 ...
- [C#详解] (1) 自动属性、初始化器、扩展方法
文章来源:Slark.NET-博客园 http://www.cnblogs.com/slark/p/CSharp-focus-1.html 代码下载:点我下载 目录 前言 属性与自动属性 属性 自动属 ...
- 02_HTML5+CSS详解第三天
WebStorage简单的网页留言板用到的函数有3个1.saveStorage函数使用"new Date().getTime()"语句来获取当前的日期和时间戳,然后使用localS ...
随机推荐
- 关于各种Formatting context
Formatting context 我们把网页看作是由很多个盒子组成的,而这些盒子的展示方式,就是由display这个属性来决定的. 这里出现了一个概念,叫做Formatting context(格 ...
- 微信小程序:优化页面要渲染的属性
问题:页面中只用到四个属性:goods_name,goods_price,goods_introduce,pics,但是整个对象中有22个属性,小程序中建议:data中只存放标签中要使用的数据,而现在 ...
- Redis6.0.9主从搭建
所谓主从,大家都知道主是写数据,而从是进行数据的拷贝. 1:配置 主节点 127.0.0.1 6379 从节点 127.0.0.1 6378 先将单机版的配置文件赋值两份出来,原先的配置中主要改动有: ...
- 2020年Python最新面试题(一):Python基础
转: 2020年Python最新面试题(一):Python基础 目录 1. 什么是 Python?使用 Python 有什么好处? 2. Python中常用的关键字有哪些? 3. Python 2.x ...
- [数据结构与算法-15]单源最短路径(Dijkstra+SPFA)
单源最短路径 问题描述 分别求出从起点到其他所有点的最短路径,这次主要介绍两种算法,Dijkstra和SPFA.若无负权优先Dijkstra算法,存在负权选择SPFA算法. Dijkstra算法 非负 ...
- Prometheus自定义指标
1. 自定义指标 为了注册自定义指标,请将MeterRegistry注入到组件中,例如: public class Dictionary { private final List<String ...
- Ubuntu更换python默认版本
设置python版本: 1 sudo update-alternatives --install /usr/bin/python python /usr/bin/python2 100 2 sudo ...
- 安装JDK9,jemter无法正常启动,怎么退回到JDK8
安装JDK8,配置环境变量 java -version显示的是8.1 然后安装JDK9之后,java -version显示的是9+8.1 这个时候,无法正常启动jemter 在环境变量中把path的C ...
- Raft共识算法详解
Raft共识算法 一.背景 拜占庭将军问题是分布式领域最复杂.最严格的容错模型.但在日常工作中使用的分布式系统面对的问题不会那么复杂,更多的是计算机故障挂掉了,或者网络通信问题而没法传递信息,这种情况 ...
- HTML的基础语法
区别于c语言这类高级语言,HTML不是编程语言,而好似一种描述型语言,用于描述网页中内容的显示方式. HTML标记以<>来进行标记.HTML中的标记按其是否成对出现,可以分为单标记和双标记 ...