background-position百分比原理

今天帮别人调代码时,看到一个样式:css

background-position: 50% 0;
background-size: 100% auto;

对background-size:100% auto,意思是背景图片宽度为元素宽度*100%,高度等比缩放。详情可见css3 backgroundhtml

对background-position很天然的觉得百分比是根据父元素宽度计算的,但background-position真的不是,它有一套本身的原理。下面详细介绍。css3

1、等价写法

在看各种教程时有如下等价写法:post

  • top left, left top 等价于 0% 0%.
  • top, top center, center top 等价于 50% 0%.
  • right top, top right 等价于 100% 0%.
  • left, left center, center left 等价于 0% 50%.
  • center, center center 等价于 50% 50%.
  • right, right center, center right 等价于 100% 50%.
  • bottom left, left bottom 等价于 0% 100%.
  • bottom, bottom center, center bottom 等价于 50% 100%.
  • bottom right, right bottom 等价于 100% 100%.

那么为何left,top就等价于0% 0%,right bottom等价于100% 100%呢?测试

2、background-position百分比计算公式

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

 有了这个公式,就很容易理解百分百写法了,推算一下也就很容易理解上面各种等价写法了。url

3、举例

一、background-position:center center等价于background-position:50% 50%等价于background-position:?px ?px3d

例子中用到背景图以下【尺寸:200px*200px】:htm

背景图在容器中居中。blog

复制代码
<style type="text/css">
.wrap{
    width: 300px;
    height: 300px;
    border:1px solid green;
    background-image: url(img/image.png);
    background-repeat: no-repeat;
/*    background-position: 50% 50%;*/
    background-position: center center;
}
</style>
<div class="wrap">
</div>
复制代码

效果都是让背景图片居中教程

如上经过设置百分比和关键字能实现背景图居中,若是要实现经过具体值来设置图片居中该设置多少?

根据上面公式:

x=(容器的宽度-背景图宽度)*x百分比=(300px-200px)*50%=50px;

y=(容器的高度-背景图高度)*y百分比=(300px-200px)*50%=50px;

即设置background-postion:50px 50px;

测试一下:

复制代码
<style type="text/css">
.wrap{
    width: 300px;
    height: 300px;
    border:1px solid green;
    background-image: url(img/image.png);
    background-repeat: no-repeat;
/*    background-position: 50% 50%;*/
/*    background-position: center center;*/
    background-position: 50px 50px;
}
</style>
<div class="wrap">
</div>
复制代码

效果一样居中。

相关文章
相关标签/搜索