饥人谷知识点三:background那些事儿

什么是background?

一个元素的背景是在其content,padding和border下的内容(当然,在新的浏览器里可以通过使用background-clip属性改变背景所占用的区域)

background具有多种不同的属性

  • background-color:设置元素的背景色
  • background-image:为页面元素指定一个或多个背景图
  • background-position:指定背景图片的初始位置
  • background-repeat:指定背景图片是否以平铺效果重复出现,以及重复的方式
  • background-attachment:决定背景是在视口中固定的还是随包含它的区块滚动的
  • background: 将以上五个属性简写在一起
  • background-size:设置背景图片大小

background-color

  • background-color的默认值是transparent而不是white
  • 该属性的使用务必要考虑到浏览器的兼容问题,在编写代码时最好先给一个基础的背景色再去设置比较鲜明的特点

举个例子
html

<p>我想拥有一个背景色</p>

CSS

p{
padding: 20px;
background-color: yellow;
}

以下为结果


background-image

background-image最简单的用法就是url(图片的路径),这样就会选取一张图片插入到背景区域

p{
padding: 20px;
background-color: yellow;
background-image: url(http://b3.hoopchina.com.cn/images/logo2013/v1/hp_logo_nba.png)
}

以下为结果



额,这个结果看起来并不是很好,背景图片看起来一直在重复且没有美感,这就需要利用以下的属性来修改

注:background只是背景而已,并不是网页内容的一部分,如果想让图片包含网页内容之中的话应该使用img标签

background-repeat

background-repeat的默认值是令图片在水平和垂直方向不断重复直至填满整个元素,其他的值包括

  • no-repeat:图片不会重复显示,只会显示一次
  • repeat-x:背景图片会沿着水平方向不断重复
  • repeat-y:背景图片会沿着垂直方向不断重复

让我们来修饰代码

p{
padding: 20px;
background-color: yellow;
background-image: url(http://b3.hoopchina.com.cn/images/logo2013/v1/hp_logo_nba.png);
background-repeat: no-repeat;
}

以下为结果



这样看起来似乎好一点了,但是背景图片确实覆盖了文本内容,我们可能需要将背景图片重新定一下位

background-position

一般来说,background-position将会取两个值,中间用空格隔开,他指定了图片的XY坐标——定位到图片左上角的点。想象这个背景是一张图片,X坐标从左到右,Y坐标从上到下
属性的取值大致有以下几种

  • 绝对值类似像素,比如background-position: 200px 25px;
  • 相对值类似rems,比如background-position: 20rem 2.5rem
  • 百分比,比如background-position: 90% 25%
  • 关键字,比如right center,这两个值比较直观,并且可以分别取左,中,右,和顶部,中部,底部的值

值得注意的是你也可以将这些值混合起来用,比如background-position: 99% center,同时如果只指定了一个值,那这个值代表水平的值,垂直方向的默认为center。
让我们再次修饰我们的代码

p{
padding: 20px;
background-color: yellow;
background-image: url(http://b3.hoopchina.com.cn/images/logo2013/v1/hp_logo_nba.png);
background-repeat: no-repeat;
background-position: 99%;
}

以下为结果


background-attachment

background-attachment指定了当网页的内容滚动时背景如何滚动,他有以下的值

  • scroll:背景图像会随着页面其余部分的滚动而移动
  • fixed:当页面的其余部分滚动时,背景图像不会移动
  • local:背景图像会随着页面其余部分的滚动而移动
  • demo

这部分没搞懂...需要高人指点

background简写

在一条语句里面声明多种background属性是可行的,属性与属性之间应该用空格分隔开,比如

background: yellow linear-gradient(to bottom, orange, yellow) no-repeat left center scroll;

我们将我们以上分不同步骤写的代码用一条语句代替

p{
padding: 20px;
background: yellow url(http://b3.hoopchina.com.cn/images/logo2013/v1/hp_logo_nba.png) no-repeat 99%
}

结果和之前的结果完全一样



简写的模板如下

background: [background-color] [background-image] [background-repeat] [background-attachment] [background-position] / [ background-size] [background-origin] [background-clip];

background-size

background-size可以允许你修改背景图片的尺寸以更好的适用于你的设计,对于每一张图片,你需要2个参数:水平的和垂直的,例如

p{
padding: 20px;
background: yellow url(http://b3.hoopchina.com.cn/images/logo2013/v1/hp_logo_nba.png) no-repeat 99% / 10%;
}

以下为结果


数值还可以是%和rems等,还可以是cover和contain

  • px
  • 第一个值设置宽度,第二个值设置高度。
    如果只设置一个值,则第二个值会被设置为 "auto"
  • %
  • 第一个值设置宽度,第二个值设置高度。
    如果只设置一个值,则第二个值会被设置为 "auto"
  • cover
  • 把背景图像扩展至足够大,以使背景图像完全覆盖背景区域
    背景图像的某些部分也许无法显示在背景定位区域中
  • contain
  • 把图像图像扩展至最大尺寸,以使其宽度和高度完全适应内容区域

demo


参考文章:


2015.8.16第一次更新

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,589评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,615评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,933评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,976评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,999评论 6 393
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,775评论 1 307
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,474评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,359评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,854评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,007评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,146评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,826评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,484评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,029评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,153评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,420评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,107评论 2 356

推荐阅读更多精彩内容

  • 1. 定义和用法 background是一个简写属性,可以在一个声明中设置所有的背景属性,可设置的属性如下: 这些...
    lightNate阅读 4,361评论 2 9
  • 学习CSS的最佳网站没有之一 http://www.w3school.com.cn/tags/index.asp ...
    Amyyy_阅读 1,060评论 0 1
  • background应该是CSS里使用频率颇高的属性,简单实用。但参数偏多,本篇就介绍一下background的各...
    张歆琳阅读 4,282评论 4 26
  • 自从lofter忘记密码账号,就只能另寻他法了,从这里开始把
    爱吃柚子的柚子阅读 197评论 0 1
  • 喝多了嘛
    白乐随心阅读 191评论 0 0