background-position 用法详细介绍

原创 2015年11月17日 15:58:17

语法: 
background-position : length || length 
background-position : position || position 
取值: 
length  : 百分数 | 由浮点数字和单位标识符组成的长度值。请参阅 长度单位  
position  : top | center | bottom | left | center | right 

说明: 
设置或检索对象的背景图像位置。必须先指定 background-image 属性。
该属性定位不受对象的补丁属性( padding )设置影响。
默认值为: 0% 0% 。此时背景图片将被定位于对象不包括补丁( padding )的内容区域的左上角。
如果只指定了一个值,该值将用于横坐标。纵坐标将默认为 50% 。如果指定了两个值,第二个值将用于纵坐标。
如果设置值为 right center ,因为 right 作为横坐标值将会覆盖 center 值,所以背景图片将被居右定位。
对应的脚本特性为 backgroundPosition。

注: 本文中使用的图片大小为 300px*120px,为了能很清晰的表达图形的哪部分被隐藏了,按照图片的大小平均分成了9等份。同时背景图片容器区域绘制出绿色边框清晰显示容器的范围。
1、background-position:0 0;
背景图片的左上角将与容器元素的左上角对齐。该设置与background-position:left top;或者background-position:0% 0%;设置的效果是一致的。例如:

    .container{
        width:300px;
        height:150px;
        background:transparent url(bg.jpg) no-repeat scroll 0 0;
        border:5px solid green;
    }

效果如下图1:


2、该属性定位不受对象的补丁属性( padding )设置影响。

例如,我们给容器元素增加padding值,背景图片的左上角还是与容器元素的左上角对齐。在此处只是影响到了容器元素的高度和宽度。

    .container{
        width:300px;
        height:150px;
        background:transparent url(bg.jpg) no-repeat scroll 0 0;
        border:5px solid green;
        padding:50px;
    }

效果如图2:



3、background-position:-70px -40px;

图片以容器左上角为参考向左偏移70px,向上偏移 40px,示例:

    .container{
        width:300px;
        height:150px;
        background:transparent url(bg.jpg) no-repeat scroll -70px -40px;
        border:5px solid green;
    }

效果如图3:



4、background-position:70px 40px;

图片以容器左上角为参考向右偏移70px,向下偏移 40px,示例:

    .container{
        width:300px;
        height:150px;
        background:transparent url(bg.jpg) no-repeat scroll 70px 40px;
        border:5px solid green;
    }

效果如图4:



5、background-position:50% 50%;

图片水平和垂直居中。与 background-position:center center;效果等同。

等同于x:{容器(container)的宽度—背景图片的宽度}*x百分比,超出的部分隐藏。
等同于y:{容器(container)的高度—背景图片的高度}*y百分比,超出的部分隐藏。

 例如: .container{
        width:300px;
        height:150px;
        background:transparent url(bg.jpg) no-repeat scroll 50% 50%;
        border:5px solid green;
    }

其x=(300-210)*50%=45px;

y=(150-120)*50%=15px;

效果如图5:



由于超出部分别往两端延伸,所以我们可以先制作一张宽度足够宽图片设置水平值为50%,这样可以用来适应不同的浏览器,使得图片水平充满浏览器窗口并且居中。替代margin:50 auto的功能。

6、background-position:-50% -50%;

等同于x:-{容器(container)的宽度—背景图片的宽度}*x百分比,超出的部分隐藏。
等同于y:-{容器(container)的高度—背景图片的高度}*y百分比,超出的部分隐藏。

    .container{
        width:300px;
        height:150px;
        background:transparent url(bg.jpg) no-repeat scroll -50% -50%;
        border:5px solid green;
    }

效果如图6:


7、background-position:100% 100%;

图片处于容器元素的右下角,与 background-position:right bottom;效果等同。

示例:

    .container{
        width:300px;
        height:150px;
        background:transparent url(bg.jpg) no-repeat scroll 100% 100%;
        border:5px solid green;
    }

效果如图7:

 

这样就比较了解其他属性了~


版权声明:本文为博主原创文章,未经博主允许不得转载。

【ibokan】background-position定位一张背景图

DIV背景定义参数:background 设置元素的背景参数,其中属性依次为      background-color(背景色)      background-image(背景图)      ...
  • huangyibin628
  • huangyibin628
  • 2014年02月28日 21:25
  • 2344

CSS Sprites(CSS雪碧图)利用background-position从大图中扣出小图

CSS Sprites技术被国内一些人称为CSS雪碧图,其实就是把网页中一些背景图片整合到一张图片文件中,再利用CSS的“background-image”,“background- repeat”,...
  • heyue_99
  • heyue_99
  • 2016年08月15日 15:08
  • 1243

HTML&CSS——对背景图定位中background-position属性的自我理解

最近在项目中需要大量的用到很多标签按钮什么的零碎图片,加上一直没机会使用Css中的”精灵技术“,这里把我对background-position的理解写成文档供更多人使用学习;如果有不对的请大家使劲拍...
  • oscar92420aaa
  • oscar92420aaa
  • 2016年05月03日 15:54
  • 2223

js自定义鼠标右键菜单

我们在浏览器上点击右键会出现一些经常见的菜单,下面我将介绍如何自定义自己的菜单。 自定义右键菜单 body,ul,li{margin:0;padding:0;} body{font:12px...
  • susuzhe123
  • susuzhe123
  • 2017年03月15日 10:25
  • 610

css控制背景图片位置-background-position

最近经常给div在加背景图片的时候,发现背景图片的位置总是跟自己想要的效果不一样,所以就粗略的研究了一下,把结果和过程跟大家一起分享一下。现在就用div来举例子,其他的容器也都一样。主要来介绍一下背景...
  • Lycop
  • Lycop
  • 2016年04月30日 18:52
  • 1538

CSS从大图中抠取小图完整教程(background-position应用)

相信很多喜欢研究网页界面的童鞋都遇到过一个奇妙的现象:网页中很多图片素材被合成在一张图片上。        起初小菜模仿网站的时候,经常遇到这个现象,那时候也不知道这时什么技术,人家的整张图...
  • qq285679784
  • qq285679784
  • 2015年10月20日 10:58
  • 227

background-position 百分比问题,精灵图的实现

background-position %
  • qq_35809245
  • qq_35809245
  • 2017年01月07日 18:00
  • 835

css中background-position:的属性值为百分比时的用法

如果定位用的是百分比话,算法比较特殊。我举个例子: background:#FFF url(image) no-repeat fixed 50% -30%; 这个时候图片应该在容器的什么位置呢,...
  • kbx8916
  • kbx8916
  • 2016年12月06日 17:49
  • 283

css sprite与background-size结合实现背景图片等比缩放

实际开发中,因为要兼容不同分辨率设备我们的sprite图片可能需要不同的尺寸,比如下面图片我们要用“活动车辆”这个标签,分别需要原图大小和缩小一半之后的图片 如果是单独的图片很好处理,但我们这是...
  • liona_koukou
  • liona_koukou
  • 2017年04月10日 14:16
  • 945

ToolBar的进阶详细使用

http://www.open-open.com/lib/view/open1431356199216.html 原文出处: 【张鸿洋的博客】 1、概述 随着Material Des...
  • RuingMan
  • RuingMan
  • 2016年06月02日 21:34
  • 2220
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:background-position 用法详细介绍
举报原因:
原因补充:

(最多只允许输入30个字)