zoukankan      html  css  js  c++  java
  • css3背景图片百分比

    原文链接:http://caibaojian.com/background-position-percent.html

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

    via对background-size:100% auto,意思是背景图片宽度为元素宽度*100%,高度等比缩放。详情可见css3 background。原文来自:http://caibaojian.com/background-position-percent.html

    对background-position很自然的以为百分比是根据父元素宽度计算的,但background-position真的不是,它有一套自己的原理。下面详细介绍。

    等价写法

    在看各类教程时有以下等价写法:

    • 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%呢?

    百分比计算公式

    任何CSS属性值为percent时,都需要根据某个参考值进行计算,搞明白这个参考值是什么,理解就容易多了。

    标准规定:background-position:perenct的参考值为: (容器宽度 - 背景图片宽度).

    //code from http://caibaojian.com/background-position-percent.html
    background-postion:x y;
    x:{容器(container)的宽度—背景图片的宽度}*x百分比,超出的部分隐藏。
    y:{容器(container)的高度—背景图片的高度}*y百分比,超出的部分隐藏。

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

    举例

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

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

    301701448211894

    背景图在容器中居中。

    <style type="text/css">
    .wrap{
         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>

    效果都是让背景图片居中

    原文来自http://caibaojian.com/background-position-percent.html

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

    根据上面公式:

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

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

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

    测试一下:

    <style type="text/css">
    .wrap{
         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>

    效果同样居中。

    推算百分比:

    从上面看出来,百分比为background-position-x的值 = (背景在雪碧中的左边宽度)/(容器宽度 - 背景图片宽度)*100%。

    平常使用 background-position,一般是用固定值,比如:

    .hello {
      background-position: 50px 50px; // 背景图片左上角离包含块左上角距离为水平方向 50px,竖直方向 50px
    }

    那如果上面的固定值 50px,我坚持要写成百分比如何?

    已知背景图片大小为 150×150,包含块大小为 200×200。

    答案是:

    .hello {
      background-position: 100% 100%;
    }
    

    这个值是这样计算的:

    50/(200-150)*100% = 100%
    

    这是因为 background-position 在使用百分比时,概念跟固定取值并不一样。

    举上面的示例说,如果设置 background-postion:10% 30%;,则是背景图片水平方向 10% 位置的点与包含块水平方向 10% 位置的点重合。换算成固定取值的话:

    (200-50)*10% = 5
    

    示意如下:

     

    但如果我们使用负的百分比,则浏览器的处理方式又跟绝对值一样了,比如:

    .test {
      background-position: -10%, -50%;
    }
    

    就是让背景图片起点定位到包含块 (-10%, -50%) 的位置。

    这个概念不十分直观,所以没细究的话,很容易误解。

    rem中的应用

    在使用自适应时,由于数字的误差导致了背景图片会出现定位出现一些小偏差问题,如果可以将背景图片通过百分比来定位,而不是默认的rem来定位,可能精准度更高点。

  • 相关阅读:
    算法学习-顺序查找
    EF框架中Attach与Entry
    EntityFramework更新实体绑定实体字段简便方法
    C# 快速写入本地文件
    Vue 3.0初探
    二维管线生成三维管线,转换3DTiles 思路
    Civil3d中 如何用管轴线的变坡点桩号控制其他纵断面数据的显示?
    jupyter
    jenkins
    ambari
  • 原文地址:https://www.cnblogs.com/lzm1989/p/5937170.html
Copyright © 2011-2022 走看看