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

    你可能感兴趣的文章
    npm install digital envelope routines::unsupported解决方法
    查看>>
    npm install 卡着不动的解决方法
    查看>>
    npm install 报错 EEXIST File exists 的解决方法
    查看>>
    npm install 报错 ERR_SOCKET_TIMEOUT 的解决方法
    查看>>
    npm install 报错 Failed to connect to github.com port 443 的解决方法
    查看>>
    npm install 报错 fatal: unable to connect to github.com 的解决方法
    查看>>
    npm install 报错 no such file or directory 的解决方法
    查看>>
    npm install 权限问题
    查看>>
    npm install报错,证书验证失败unable to get local issuer certificate
    查看>>
    npm install无法生成node_modules的解决方法
    查看>>
    npm install的--save和--save-dev使用说明
    查看>>
    npm node pm2相关问题
    查看>>
    npm run build 失败Compiler server unexpectedly exited with code: null and signal: SIGBUS
    查看>>
    npm run build报Cannot find module错误的解决方法
    查看>>
    npm run build部署到云服务器中的Nginx(图文配置)
    查看>>
    npm run dev 和npm dev、npm run start和npm start、npm run serve和npm serve等的区别
    查看>>
    npm run dev 报错PS ‘vite‘ 不是内部或外部命令,也不是可运行的程序或批处理文件。
    查看>>
    npm scripts 使用指南
    查看>>
    npm should be run outside of the node repl, in your normal shell
    查看>>
    npm start运行了什么
    查看>>