20131227-backgroundPosition

background-position 用法详细介绍

语法:

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:

??????????????????????????????????????? 图 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:

?????????????????????????????????????????????????? 图 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:

????????????????????????????????? 图 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:

?????????????????????????????????? 图 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:

???????????????????????????????????? 图 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:

???????????????????????????????????? 图 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:

??????????????????????????????????? 图 7

Ref: http://blog.csdn.net/JeamKing/article/details/5617088

时间: 2024-11-07 05:10:43

20131227-backgroundPosition的相关文章

background-position百分比原理

今天帮别人调代码时,看到一个样式: background-position: 50% 0;background-size: 100% auto: 对background-size:100% auto,意思是背景图片宽度为元素宽度*100%,高度等比缩放.详情可见css3 background. 对background-position很自然的以为百分比是根据父元素宽度计算的,但background-position真的不是,它有一套自己的原理.下面详细介绍. 一.等价写法 在看各类教程时有以下等

background-position 用法详细介绍(转载)

语法: background-position : length || length background-position : position || position 取值: length  : 百分数 | 由浮点数字和单位标识符组成的长度值.请参阅 长度单位  position  : top | center | bottom | left | center | right 说明: 设置或检索对象的背景图像位置.必须先指定 background-image 属性.该属性定位不受对象的补

火狐不支持backgroundPosition的js插件

用js backgroundPositionX,backgroundPositionY设置在firefox下无法识别,用backgroundPosition同样在火狐无法识别.要识别只能用js插件来实现的,代码如下: /** * @author Alexander Farkas * v. 1.02 */ (function($) { $.extend($.fx.step,{ backgroundPosition: function(fx) { if (fx.state === 0 && t

IE8和IE7如何获取background-position属性值

IE8和IE7如何获取background-position属性值:之所以要单独介绍一下如何获取background-position属性值,是因为在IE8和IE8以下浏览器中存在一定的兼容性问题,下面对此做一下简单介绍,希望能够给需要的朋友带来帮助.一.使用style方式:此方式只能够获取使用style方式定义的css样式属性,代码如下: <!DOCTYPE html> <html> <head> <meta charset="utf-8"&

background-position的百分比

background-position的百分比属性规则是:图片本身(x%,y%)的那个点,与背景区域的(x%,y%)的那个点重合. 具体可参考: http://www.ruanyifeng.com/blog/2008/05/css_background_image_positioning.html

CSS background-position 属性

background-position 属性设置背景图像的起始位置. 语法: background-position : length || length background-position : position || position 取值: length  :百分数 | 由浮点数字和单位标识符组成的长度值position  : top | center | bottom | left | center | right 1.background-position没有设置时,默认是backg

css background-position属性

background-position 属性设置背景图像的起始位置. 这个属性设置背景原图像(由 background-image 定义)的位置,背景图像如果要重复,将从这一点开始. 提示:您需要把 background-attachment 属性设置为 "fixed",才能保证该属性在 Firefox 和 Opera 中正常工作. 默认值: 0% 0% 继承性: no 版本: CSS1 JavaScript 语法: object.style.backgroundPosition=&q

background-position 使用方法具体介绍

语法: background-position : length || length background-position : position || position 取值: length  : 百分数 | 由浮点数字和单位标识符组成的长度值.请參阅 长度单位  position  : top | center | bottom | left | center | right 说明: 设置或检索对象的背景图像位置.必须先指定 background-image 属性. 该属性定位不受对象的

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

转:http://www.cnblogs.com/iyangyuan/archive/2013/06/01/3111704.html 相信很多喜欢研究网页界面的童鞋都遇到过一个奇妙的现象:网页中很多图片素材被合成在一张图片上. 起初小菜模仿网站的时候,经常遇到这个现象,那时候也不知道这时什么技术,人家的整张图片素材不会利用,只能用ps切图,切成单个的再用... 其实,这是一个非常简单的技术,就是因为想象的太难了,才一直找不到问题的关键. 要想实现CSS抠图,只需要用到一个属性:backgroun

background-position还可以这样用

文章同步至微信公众号:http://mp.weixin.qq.com/s?__biz=MzAxMzgwNDU3Mg==&mid=401626453&idx=1&sn=6af07474df847d251358c4b453eaddfd#wechat_redirect 感兴趣的可以扫码关注哈: background-position这个样式规则,切页面的同学应该都用过.关于其详细介绍,就不再赘述了.http://www.cnblogs.com/huazaizai/archive/2010