博客
关于我
纯css实现容器高度随宽度等比例变化的两种解决方案
阅读量:321 次
发布时间:2019-03-04

本文共 481 字,大约阅读时间需要 1 分钟。

(padding-bottom实现的正方形)

  • padding-bottom实现
  • 这个方法非常巧妙。由于padding-bottom的属性值百分比是按照父容器的宽度来计算的,所以我们可以设置容器的宽度为父容器的50%,padding-bottom也为50%。这样,无论是宽度还是高度,都会自动占用父容器的50%。这样一来,盒子就会显示成一个完美的正方形。

    1. 使用隐藏图片实现
    2. 这种方法无需担心兼容性问题,在PC和移动端都能完美运行。只是增加了一个DOM结构,但相比于一个页面中百上千的代码,这个成本微乎其微。

      我们知道,div容器如果不设置高度,其高度会随着内部元素的变化而自动扩展。在这种情况下,我们在容器内部添加一张图片,并设置图片的宽度为100%,高度为auto。这样,无论父容器如何变化,图片都会严格按照宽高比例自动缩放,内部容器的高度也会随之调整。

      相比于padding-bottom实现,使用图片可能会存在一定的高度误差,这需要根据实际需求进行调整。

      使用图片实现的优势在于代码简洁,不需要额外处理。对于大多数浏览器和屏幕尺寸,这种方法都能达到理想效果。

    转载地址:http://zqvq.baihongyu.com/

    你可能感兴趣的文章
    OSG学习:几何体的操作(二)——交互事件、Delaunay三角网绘制
    查看>>
    OSG学习:几何对象的绘制(一)——四边形
    查看>>
    OSG学习:几何对象的绘制(三)——几何元素的存储和几何体的绘制方法
    查看>>
    OSG学习:几何对象的绘制(二)——简易房屋
    查看>>
    OSG学习:几何对象的绘制(四)——几何体的更新回调:旋转的线
    查看>>
    OSG学习:场景图形管理(一)——视图与相机
    查看>>
    OSG学习:场景图形管理(三)——多视图相机渲染
    查看>>
    OSG学习:场景图形管理(二)——单窗口多相机渲染
    查看>>
    OSG学习:场景图形管理(四)——多视图多窗口渲染
    查看>>
    OSG学习:新建C++/CLI工程并读取模型(C++/CLI)——根据OSG官方示例代码初步理解其方法
    查看>>
    Sql 随机更新一条数据返回更新数据的ID编号
    查看>>
    OSG学习:空间变换节点和开关节点示例
    查看>>
    OSG学习:纹理映射(一)——多重纹理映射
    查看>>
    OSG学习:纹理映射(七)——聚光灯
    查看>>
    OSG学习:纹理映射(三)——立方图纹理映射
    查看>>
    OSG学习:纹理映射(二)——一维/二维/简单立方图纹理映射
    查看>>
    OSG学习:纹理映射(五)——计算纹理坐标
    查看>>
    OSG学习:纹理映射(六)——灯光
    查看>>
    OSG学习:纹理映射(四)——三维纹理映射
    查看>>
    OSG:从源码看Viewer::run() 一
    查看>>