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

    你可能感兴趣的文章
    Notepad ++ 安装与配置教程(非常详细)从零基础入门到精通,看完这一篇就够了
    查看>>
    Notepad++在线和离线安装JSON格式化插件
    查看>>
    notepad++最详情汇总
    查看>>
    notepad++正则表达式替换字符串详解
    查看>>
    notepad如何自动对齐_notepad++怎么自动排版
    查看>>
    Notes on Paul Irish's "Things I learned from the jQuery source" casts
    查看>>
    Notification 使用详解(很全
    查看>>
    NotImplementedError: Cannot copy out of meta tensor; no data! Please use torch.nn.Module.to_empty()
    查看>>
    NotImplementedError: Could not run torchvision::nms
    查看>>
    nova基于ubs机制扩展scheduler-filter
    查看>>
    Now trying to drop the old temporary tablespace, the session hangs.
    查看>>
    nowcoder—Beauty of Trees
    查看>>
    np.arange()和np.linspace()绘制logistic回归图像时得到不同的结果?
    查看>>
    np.power的使用
    查看>>
    NPM 2FA双重认证的设置方法
    查看>>
    npm build报错Cannot find module ‘webpack/lib/rules/BasicEffectRulePlugin‘解决方法
    查看>>
    npm build报错Cannot find module ‘webpack‘解决方法
    查看>>
    npm ERR! ERESOLVE could not resolve报错
    查看>>
    npm ERR! fatal: unable to connect to github.com:
    查看>>
    npm ERR! Unexpected end of JSON input while parsing near '...on":"0.10.3","direc to'
    查看>>