• css 高度随宽度比例变化


    【方案一:padding实现】

    原理:

    一个元素的 padding,如果值是一个百分比,那这个百分比是相对于其父元素的宽度而言的,padding-bottom 也是如此。

    使用 padding-bottom 来代替 height 来实现高度与宽度成比例的效果,将 padding-bottom设置为想要实现的 height 的值。同时将

    其 height 设置为 0 以使元素的“高度”等于 padding-bottom 的值,从而实现需要的效果。

    <div class="father">
        <div class="childbox"></div>
    </div>
    <style type="text/css">
    .childbox{
      padding-bottom: 20%;
       20%;
      height: 0;
      background: #888888;
    }
    </style>


    上例宽高比是1比1,实现的是正方形,并且根据父级盒子宽度实现等比缩放

    【方案二:一个隐藏的图片来实现】

    原理:

    div容器如果不给定高度,它的高度会随着容器内部的元素变化而撑大,这个时候,我们在容器内部添加一张符合我们宽高比例的图片,给图片设置宽度100%;高度auto,我们知道图片只设置宽度的话,高度会随宽度来进行比例变化,自动缩放,这样我们内部的子容器的高度也就会按照比例缩放了。当然这个img你可以占位隐藏,也可以用别的盒子覆盖上。

    #container {
       100%;
    }
    .attr {
      background-color: #008b57;
    }
    .attr img{
       100%;
      height: auto;
    }
    </style>
    <div id='container'>
      <div class='attr'>
        <img src="1.png" alt="">
      </div>
    </div>


    这个方法不需要考虑任何兼容性,PC移动完美运行。除了增加了一个dom结构,但是一个页面成百上千的代码来说,不值一提。

    如果你觉得增加img标签多发了http请求,那么base64图片编码可以解决这个问题,由于我们的的图片只需要一个形状而已,所

    以可以大胆的压缩,然后编码,连http请求都省了。

    【方案三:vw,vh】

    css3的新单位(css3大法好~),我们将父容器的宽度和高度定义为相同的vw,这样父容器的高度和宽度就是相同值,这个时候,子容器的宽高值设为百分比,不管父容器大小如何变,子容器的高度和宽度比都是不会变的

    单位 说明
    vw 相对于视窗的宽度
    vh 相对于视窗的高度
    vmin 相对于视口的宽度或高度中较小的那个被均分为100单位的vmin

    vmax 相对于视口的宽度或高度中较大的那个被均分为100单位的vmax

    <div class="father">
        <div class="childbox"></div>
    </div>
    .childbox{    
       20%;
      height: 20vw;
      background: #888888;
    }

    .

  • 相关阅读:
    C#中get和set的写法
    FineUI中Newtonsoft.Json版本报错解决办法
    ExtAspNet和FineUI未将对象引用设置到对象的实例
    【转载】写runat="server"有什么用
    (object sender,EventArgs e)是什么?
    【转载】onclick与onCommand的区别
    简单总结------redis
    将list等分成n份
    将List 分成n个长度由调用者指定的子List
    CountDownLatch 我的应用场景
  • 原文地址:https://www.cnblogs.com/fightjianxian/p/11920799.html
Copyright © 2020-2023  润新知