开发者社区> 问答> 正文

移动端web还原设计稿比例问题

screenshot
是这样的一个问题,大家看到,中间的两个图片,宽度是100%的,需求是希望中间这个div宽度100%,然后高度保持设计稿的比例,可惜移动端有些比较奇葩的尺寸(小米平板,ipad,iPhone4),
有木有什么办法

展开
收起
杨冬芳 2016-06-01 19:28:11 2203 0
1 条回答
写回答
取消 提交回答
  • IT从业

    html代码

    <div class="box-container">
      <div class="box">
        <img src="" alt=""/>
      </div>
    </div>
    

    less代码

    .box-container {
      position: relative;
      width: @img-width;
      &:before {
        content: '';
        display: block;
        padding: 100% 0 0 0; // 这里的top的值为img的高和宽的百分比值,100%时构建的是响应式正方形
      }
      .box {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
      }
      .img {
        display: block;
        width: 100%;
        height: auto;
      }
    }

    这里神奇的神奇的地方,在于box-container:before,对于before的 padding-top 的百分比的最终计算值是相对 width 来计算的,所以当 padding-top: 100% ,将构建出一响应式正方形,当 padding-top: 50% 将构建出width:height = 2:1的响应式长方形

    当通过before将 div.box-container 容器撑成响应式容器时,让 div.box 绝对定位于父容器并且高度和宽度等于100%,使其成为能实际存放元素的容器

    2019-07-17 19:23:43
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
Web应用系统性能优化 立即下载
高性能Web架构之缓存体系 立即下载
PWA:移动Web的现在与未来 立即下载