CSS属性:背景属性(图文详解)

本文最初发表于博客园,并在GitHub上持续更新前端的系列文章。欢迎在GitHub上关注我,一块儿入门和进阶前端。css

如下是正文。html

background系列属性

常见背景属性

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,它的做用是:将上面的多个属性写在一个声明中。网站

上面这几个属性常常用到,须要记住。如今咱们逐个进行讲解。搜索引擎

background-color:背景颜色的表示方法

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: 描述左右的词 描述上下的词;
  • 描述左右的词:left、center、right
  • 描述上下的词:top 、center、bottom

好比说,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属性

  • background-attachment:scroll; 设置背景图片是否固定。属性值能够是:
    • fixed(背景就会被固定住,不会被滚动条滚走)。
    • scroll(与fixed属性相反,默认属性)

background-attachment:fixed;的效果以下:

background综合属性

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)。

扫一扫,你将发现另外一个全新的世界,而这将是一场美丽的意外:

相关文章
相关标签/搜索