博客
关于我
纯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/

    你可能感兴趣的文章
    OA项目之我的会议(会议排座&送审)
    查看>>
    OA项目之我的会议(查询)
    查看>>
    OA项目之我的审批(会议查询&会议签字)
    查看>>
    OA项目之项目简介&会议发布
    查看>>
    ObjC的复制操作
    查看>>
    Object c将一个double值转换为时间格式
    查看>>
    object detection之Win10配置
    查看>>
    object detection训练自己数据
    查看>>
    object detection错误Message type "object_detection.protos.SsdFeatureExtractor" has no field named "bat
    查看>>
    object detection错误之Could not create cudnn handle: CUDNN_STATUS_INTERNAL_ERROR
    查看>>
    object detection错误之no module named nets
    查看>>
    Object of type 'ndarray' is not JSON serializable
    查看>>
    Object Oriented Programming in JavaScript
    查看>>
    object references an unsaved transient instance - save the transient instance before flushing
    查看>>
    Object 类的常见方法有哪些?
    查看>>
    Object-c动态特性
    查看>>
    Object.assign用法
    查看>>
    Object.create
    查看>>
    Object.defineProperty详解
    查看>>
    Object.keys()的详解和用法
    查看>>