zoukankan      html  css  js  c++  java
  • [老法新用]使用PADDING-TOP:(PERCENTAGE)实现响应式背景图片

    处理响应式布局中背景图片的简单方法是等比例缩放背景图片。我们知道宽度设为百分比的  <img> 元素,其高度会随着宽度的变化自动调整,且其宽高比不变。如果想在背景图片中实现同样的效果,我们必须先解决如何保持HTML元素的宽高比。

    固定宽高比

    我们将用到一个保持元素宽高比的技巧:为元素添加垂直方向的padding值,padding值使用百分比。这是因为垂直方向的padding取值使用百分比时,其值是相对于包含块的宽度而定的[参考Box model]。这个技巧最早在Creating Intrinsic Ratios for Video一文中用来创建固有比率的视频,查看demo

    假设我们有一张800*450px的图片,我们需要创建一个元素在其宽度变化时,它的宽高比仍保持16:9。代码如下:

    <div class="column">
      <div class="figure"></div>
    </div>
    
    .column{
      max- 800px;
    }
    .figure{
      padding-top: 56.25%;  /* 450px/800px = 0.5625 */
    }
    

     自己动手试试吧 demo

    添加背景图片

    上面我们实现了元素缩放并保持宽高比。但是此时如果我们添加了背景图片,它并不能跟随元素一起自动缩放。还需要添加background-size:cover。使用这个属性让背景铺满元素的缺点是IE8及以下浏览器不支持,为了使IE下的效果可以接受,可以使用background-position将背景图片居中显式。我们必须要保证图片的宽度至少要与元素的max-width一样大。这样的话元素的宽度永远不会比图片大,如果元素小于图片时,图片将被裁剪。

    div.column {
      /* The background image must be 800px wide */
      max- 800px;
    }
    
    figure.fixedratio {
      padding-top: 56.25%;  /* 450px/800px = 0.5625 */
      background-image: url(http://domain.com/img/sample.jpg);
      background-size: cover;
      background-position: center;  /* Internet Explorer 7/8 */
    }
    

     再动手试试吧  demo

    流动宽高比

    我们可以更深入一步。假设我们有一张在桌面浏览器下显式很好的宽屏图片,在移动设备上我们不想使用相同的宽高比,要不然图片会很小。又或者是我们不想使用相同的高度,因为图片可能会过高。

    这个效果可以通过较少padding的百分比值和为元素设置一个高度来实现。假设我们的大图是800*200px,我们打算在元素的宽度减少到300px的时候,背景图片的高度为150px。现在我们计算下height和padding-top属性值。

    上图显式了两个尺寸的关系。坡度线(slop)对应于padding-top属性,开始高度(start height)对应于height属性,它表示元素在宽度为零时的高度。调整样式如下:

      

    div.column {
      /* The background image must be 800px wide */
      max- 800px;
    }
    figure.fluidratio {
      padding-top: 10%;  /* slope */
      height: 120px;  /* start height */
      background-image: url(http://domain.com/img/sample.jpg);
      background-size: cover;
      background-position: center;  /* Internet Explorer 7/8 */
    }
    

      动手试试吧 demo

  • 相关阅读:
    软件开发测试模式:迭代→全功能模式
    LUN挂载到Linux主机后,如何对磁盘进行分区
    MySQL性能优化方法四:SQL优化
    MySQL性能优化方法三:索引优化
    MySQL性能优化方法二:表结构优化
    MySQL性能优化方法一:缓存参数优化
    MySQL配置文件my.ini或my.cnf的位置
    javascript今生前世
    如何在sublime中使用sass
    全栈最后一公里
  • 原文地址:https://www.cnblogs.com/hailun/p/6477797.html
Copyright © 2011-2022 走看看