本文最初发表于博客园,并在GitHub上持续更新前端的系列文章。欢迎在GitHub上关注我,一块儿入门和进阶前端。css
如下是正文。html
CSS样式中,常见的背景属性有如下几种:(常常用到,要记住)前端
background-color:#ff99ff;
设置元素的背景颜色。git
background-image:url(images/2.gif);
将图像设置为背景。github
background-repeat: no-repeat;
设置背景图片是否重复及如何重复,默认平铺满。(重要)浏览器
no-repeat
不要平铺;repeat-x
横向平铺;repeat-y
纵向平铺。background-position:center top;
设置背景图片在当前容器中的位置。微信
background-attachment:scroll;
设置背景图片是否跟着滚动条一块儿移动。 属性值能够是:scroll
(背景图片不动)、fixed
(背景图片跟着滚动条一块儿移动)。注意属性值的含义不要搞反了,它的含义是根据滚动条来定义的。学习
另外还有一个简写属性叫作background
,它的做用是:将上面的多个属性写在一个声明中。网站
上面这几个属性常常用到,须要记住。如今咱们逐个进行讲解。搜索引擎
css2.1中,背景颜色的表示方法有三种:单词、rgb表示法、十六进制表示法。
好比红色能够有下面的三种表示方法:
background-color: red; background-color: rgb(255,0,0); background-color: #ff0000;
下面分别介绍。
一、用英语单词来表示:
可以用英语单词来表述的颜色,都是简单颜色。好比红色:
background-color: red;
二、rgb表示法:
rgb表示三原色“红”red、“绿”green、“蓝”blue。
光学显示器中,每一个像素都是由三原色的发光原件组成的,靠明亮度不一样调成不一样的颜色的。r、g、b的值,每一个值的取值范围0~255,一共256个值。
好比红色:
background-color: rgb(255,0,0);
黑色:
background-color: rgb(0,0,0);
颜色能够叠加,好比黄色就是红色和绿色的叠加:
background-color: rgb(255,255,0);
三、十六进制表示法:
好比红色:
background-color: #ff0000;
PS:全部用#开头的值,都是16进制的。
这里,咱们就要学会16进制与10进制之间的转换。下面举几个例子。
问:16进制中28等于10进制多少? 答:2*16+8 = 40。
16进制中的af等于10进制多少? 答:10 * 16 + 15 = 175
因此,#ff0000就等于rgb(255,0,0)。
background-color: #123456;
等价于background-color: rgb(18,52,86);
十六进制能够简化为3位,全部#aabbcc的形式,可以简化为#abc。举例以下:
好比:
background-color:#ff0000;
等价于:
background-color:#f00;
好比:
background-color:#112233;
等价于:
background-color:#123;
可是,好比下面这个是没法简化的:
background-color:#222333;
再好比,下面这个也是没法简化的:
background-color:#123123;
几种常见的颜色简写能够记住。以下:
#000 黑 #fff 白 #f00 红 #222 深灰 #333 灰 #ccc 浅灰
background-repeat
属性(重要)background-repeat:no-repeat;
设置背景图片是否重复及如何重复,默认平铺满。属性值能够是:
no-repeat
(不要平铺)repeat-x
(横向平铺)repeat-y
(纵向平铺)这个属性在开发的时候也是常常用到的。咱们经过设置不一样的属性值来看一下效果吧:
(1)不加这个属性时:(即默认时)(背景图片会被平铺满)
PS:padding的区域也是有背景图的。
(2)属性值为no-repeat
(不要平铺)时:
(3)属性值为repeat-x
(横向平铺)时:
其实这种属性的做用仍是很广的。举个例子,设计师设计一张宽度只有1px、颜色纵向渐变的图片,而后咱们经过这个属性将其进行水平方向的平铺,就能够看到整个页面都是渐变的了。
在搜索引擎上搜“平铺背景”,就能够发现,周期性的图片能够采用此种方法进行平铺。
(4)属性值为repeat-y
(纵向平铺)时:
background-position
属性background-position
属性指的是背景定位属性。公式以下:
在描述属性值的时候,有两种方式:用像素描述、用单词描述。下面分别介绍。
一、用像素值描述属性值:
格式以下:
background-position:向右偏移量 向下偏移量;
属性值能够是正数,也能够是负数。好比:100px 200px
、-50px -120px
。
举例以下:
二、用单词描述属性值:
格式以下:
background-position: 描述左右的词 描述上下的词;
好比说,right center
表示将图片放到右边的中间;center center
表示将图片放到正中间。
位置属性有不少使用场景的。咱们来举两个例子。
场景1:(大背景图)
打开“暗黑3 台湾”的官网https://tw.battle.net/d3/zh/,能够看到官网的效果是比较炫的:
检查网页后,找到网站背景图片的url:https://tw.battle.net/d3/static/images/layout/bg-repeat.jpg。背景图以下:
实际上,咱们是经过把这张图片做为网站的背景图来达到显示效果的。只须要给body标签加以下属性便可:
body{ background-image: url(/Users/smyhvae/Dropbox/img/20170812_1950.jpg); background-repeat: no-repeat; background-position: center top; }
上方代码中,若是没加background-position
这个属性,背景图会默认处于浏览器的左上角(显得很丑);加了此属性以后,图片在水平方向就位于浏览器的中间了。
场景2:(通栏banner)
不少网站的首页都会有banner图(网站最上方的全屏大图叫作「通栏banner」),这种图要求横向的宽度特别大。好比说,设计师给你一张1920*465的超大banner图,若是咱们把这个banner图做为img标签直接插入网页中,会有问题的:首先,图片不在网页的中间;其次,确定会出现横向滚动条。以下图所示:
正确的作法是,将banner图做为div的背景图,这样的话,背景图超出div的部分,会自动移溢出。须要给div设置的属性以下:
div{ height: 465px; background-image: url(http://img.smyhvae.com/20170813_1053.jpg); background-position: center top; background-repeat: no-repeat; }
上方代码中,咱们给div设置height(高度为banner图的高度),不须要设置宽度(由于宽度会自动霸占整行)。效果以下:
上图能够看出,将banner图做为div的背景后,banner图会永远处于网页的正中间(水平方向来看)。
background-attachment:scroll;
设置背景图片是否固定。属性值能够是:
fixed
(背景就会被固定住,不会被滚动条滚走)。scroll
(与fixed属性相反,默认属性)background-attachment:fixed;
的效果以下:
background属性和border同样,是一个综合属性,能够将多个属性写在一块儿。(在盒子模型这篇文章中专门讲到boder)
举例1:
background:red url(1.jpg) no-repeat 100px 100px fixed;
等价于:
background-color:red; background-image:url(1.jpg); background-repeat:no-repeat; background-position:100px 100px; background-attachment:fixed;
之后,咱们能够用小属性层叠掉大属性。
上面的属性中,能够任意省略其中的一部分。
好比说,对于下面这样的属性:
background: blue url(images/wuyifan.jpg) no-repeat 100px 100px;
效果以下:
PS:之后的CSS3内容中,咱们会接触到更多的background属性: background-origin、background-clip、background-size(在CSS2.1背景图片是不能调整尺寸,IE9开始兼容)、多背景。
##个人公众号
想学习<font color=#0000ff>代码以外的软技能</font>?不妨关注个人微信公众号:生命团队(id:vitateam
)。
扫一扫,你将发现另外一个全新的世界,而这将是一场美丽的意外: