CSS3背景
注意:由于CSS3中的部分内容尚未完全定稿,所以本文的部分可能会随时更新。
Background是CSS Level1就开始支持的属性,用于设置元素背景相关内容。Background
是一个复合属性,它包含如下几个子属性,
background-color
,规定要使用的背景颜色background-position
,规定背景图像的位置background-size
,规定背景图片的尺寸background-repeat
,规定如何重复背景图像background-clip
,规定背景的绘制区域background-origin
,规定背景图片的定位区域background-attachment
,规定背景图像是否固定或者随着页面的其余部分滚动background-image
,规定要使用的背景图像
其中background-size
,background-clip
,background-origin
,这几个属性是CSS3 Level3中关于background
新增的属性。本篇文章将会简单阐述CSS Level1~CSS Level2中的属性,稍微详细点描述CSS Level3新增的几个属性。
已有属性
background-color
其语法如下,
background-color: <color> | transparent
background-color
用于设置元素的背景颜色,其值可以是一个颜色值(可以为多种颜色的表达,比如RGB、十六进制、特定值’red’等)或者为transparent
。默认值为transparent
,意为透明,即啥颜色也不设置。
background-position
其语法如下,
background-position: <percentage> || <length> || [left|center|right][,top|center|bottom]
background-position
用于设置背景图片的位置参数。它有多种赋值模式,可以形如(0,0)
、(0%,0%)
,或者是使用’left’,’top’,’center’,’right’,’bottom’等字段进行设置。
在设置background-position
属性时,脑子里需要有这样一个概念。以左上角(0,0)的位置为坐标系的原点,向右延伸为X轴,向下延伸为Y轴。所以形如(0,0)
、(0%,0%)
的赋值其实是表明了背景图像距离坐标系原点的距离。而’left’意为(0%, Y)
,’right’意为(100%, Y)
,’center’意为(50%, Y)
,’top’和’bottom’的含义与其相似。
background-repeat
其语法如下,
background-repeat: repeat || repeat-x || repeat-y || no-repeat
background-repeat
用于设置background-image
(背景图片)在元素中的铺放风格的,其默认值为repeat
,意为图片沿着右方(X轴方向)和下方(Y轴)同时平铺。
所以,repeat-x
意为只沿着X轴方向平铺,repeat-y
意为只沿着Y轴方向平铺,no-repeat
意为不作任何平铺。
background-attachment
其语法如下,
background-attachment: scroll || fixed
background-attachment
用于设置背景图像是否固定活着随着页面的滚动而滚动。其默认值scroll
,表示背景图片会随着页面滚动而滚动;取值为fixed
时,背景图片固定不动。
background-image
其语法如下,
background-image: none || <url>
background-image
用于设置元素的背景图片,其默认值为none
,<url>
为背景图片的地址,可用绝对地址亦可用相对地址。
新增属性
background-size
其语法如下,
background-size: auto || <length> || <percentage> || cover || contain
background-size
属性用于设置背景的大小。其中,auto
就是使用图片的原生宽高,<length>
和<percentage>
就是设置一个具体的值。这三个属性没什么还说的。下面说下cover
和contain
这两个赋值的含义。
cover
:把背景图像扩展至足够大,以使背景图像完全覆盖背景区域。背景图像的某些部分也许无法显示在背景定位区域中。contain
:把图像图像扩展至最大尺寸,以使其宽度和高度完全适应内容区域。
需要注意的是,这两种取值都会导致图片失真。这里有一个示例可以体验两者的不同。
额外补充一点,当使用<length>
或者<percentage>
进行赋值时,我们可以只赋一个值,比如background-size: 100px
,此时相当于background-size: 100px 100px
。
兼容性:IE9+、Firefox 4+、Opera、Chrome以及Safari 5+支持background-size
属性,所以在实际使用background-size
属性时针对不同浏览器需要带上其前缀。
background-clip
其语法如下,
background-clip : border-box || padding-box || content-box
background-clip
属性用于设置背景的裁剪区域,即控制元素的背景实际显示区域的大小。
border-box
,此为默认值,元素背景区域包含border
区域及其之内的padding
和content
区域。padding-box
,元素背景区域包含padding
及其之内的content
区域。content-box
,元素背景区域仅包含content
区域。
各个取值的不同效果展示,可参阅这个示例。
这里所说的border
、padding
、content
等区域其实是CSS盒模型的组成部分,更多内容可参阅CSS盒模型科普。
兼容性:IE9+、Firefox、Opera、Chrome以及Safari支持background-clip
属性,所以在实际使用background-clip
属性时针对不同浏览器需要带上其前缀。
background-origin
其语法如下,
background-origin: padding-box || border-box || content-box
background-origin
属性用于设置背景的background-position
属性相对什么来定位。
padding-box
,此为默认值,相对于内边距(padding
的外边沿)来定位。border-box
,相对于边框(border
的外边沿)来定位。content-box
,相对于内容(content
的外边沿)来定位。
各个取值的不同效果展示,可参阅示例。
兼容性:IE9+、Firefox 4+、Opera、Chrome以及Safari 5+支持background-origin
属性,所以在实际使用background-origin
属性时针对不同浏览器需要带上其前缀。
CSS3 Multiple Background
CSS3的background
属性允许设置多个除了background-color
之外的属性。比如,
background-image: url1,url2,...,urlN;
background-repeat: repeat1,repeat2,...,repeatN;
background-position: position1,position2,...,positionN;
background-size: size1,size2,...,sizeN;
backrgound-attachment: attachment1,attachment2,...,attachmentN;
background-clip: clip1,clip2,...,clipN;
background-origin: origin1,origin2,...,originN;
所以利于这一点我们可以仅在一个元素上同时设置多个背景来达到以往需要多个元素配合才能达到的效果。
参考列表
- http://www.w3.org/TR/css3-background/
- CSS3 Background-size
- CSS3 Background-clip
- CSS Background-origin
- CSS3 Multiple Backgrounds
更多建议: