CSS实现容器高度随宽度固定比例缩放的解决方案

今天做做图表过程中遇到一个问题,我的容器宽度都是使用Bootstrap那一套栅格系统,做出来之后在自己电脑上基本没什么大问题,但是放到老板的电脑屏幕上,却变得一长条的,原因就在于我把容器的高度设定为固定的300px,然而在屏幕分辨率高(或者说像素密度高)的屏幕上300px的高度相对于按50%的宽度,就成了一个横条了。

突然我就想,是不是可以让这个容器的宽高比固定一下呢?开完会后开始请教度娘,度娘里的众多结果中,无非就是那么四种方法,下面就来介绍以下这些方法以及我使用后的一些改进。

使用一个隐藏的图片来实现

这个方法我比较推荐,因为不需要考虑任何兼容性,PC移动完美运行。除了增加一个DOM结构,但是相对于一个页面成百上千的代码来说,不值一提。

我们知道,div容器如果不给定高度,它的高度会随着容器内部的元素变化而撑大,这个时候,我们在容器内部添加一张符合我们宽高比的图片,给图片设置宽度100%;高度auto。不管我们的父容器如何变化,内部的img宽度都是100%,图片是会严格按照比例自动缩放的,相应的,我们内部的子容器的盖度也就会按照比例缩放了:

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

如果你觉得增加img标签多发了http 请求,那么请继续往下看,神器base64 图片编码帮你解决这个问题,由于我的图片只需要一个形状而已,所以可以大胆的压缩,然后编码,连http请求都省了,嘎嘎~~

<img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMgAAABkAQMAAAD5SO1IAAAAA1BMVEUAAACnej3aAAAAAXRSTlMAQObYZgAAABlJREFUSMftwYEAAAAAw6D7U19gCNUAACAcCigAAeZ4u9wAAAAASUVORK5CYII=" alt="">

笔者注:
这个方法我是比较推荐的,因为实现起来很简单,兼容性也好。但是我觉得还是在attr容器里面在加一个宽高都设为100%的容器用来放最终的内容比较稳妥一些,因为如果直接在 .sttr 里面放内容的话,里面的内容很可能会把 .attri再次撑大,这可不是我们想要的。

使用vw 单元

vw 的大小是通过viewport 的宽度设定的,因此可以通过该方法保持容器按照一定的比例显示。
笔者也是现在才知道还有vw这样的单位,真是学海无涯啊。
先介绍以下vw是啥子东东:
这是一个视口比例长度单位。
关于长度的详细介绍可到MDN开发者文档 中查看。
这里简单说明以下:
vw 相对于视口的宽度,一个单位为百分之一视口宽度
vh 相对于视口的高度,一个单位为百分之一视口高度
vmin 相对于视口宽度和高度中较小的那个平均分为100份,一份为一个单位
vmax 相对于视口宽度和高度中较大的那个平均分为100份,一份为一个单位

言归正传,这样的话:

#container{
    width: 100vmin;
    height: 100vmin;
}
.attr {
    width: 50%;
    height: 50%;
    background-color: orange;
}

这样就可以得到跟屏幕的宽高比相同的容器尺寸了,然而这个方法局限性很大,都是以视口的宽高比为基准。

使用calc

calc()是CSS3的新特性,它的值可以是一个表达式。这里我们关心的是,calc() 中的百分比也是按照父容器的百分比来计算的。

.attr{
  width:50%;
  height: calc(50%);
}

通过设定padding-top 或 padding-bottom 来实现

这个方法跟第一个方法一样,都是我比较推荐的方法,我所采用的就是这个方法。
padding-top、padding-bottom 的百分比是根据父容器的width(宽度)计算的,而不是height(高度)。
比例对照表:

aspect ratio padding-bottom value
16:9 56.25%
4:3 75%
3:2 66.66%
8:5 62.5%
<style>
.box{
    padding-bottom:56.25%;
    width:100%;
    position:relative;
}
.container{
    width:100%;
    height:100%;
    position:absolute;
}
</style>
<div class="col-xs-6"><!-- 父容器 -->
    <div class="box">
        <div class="container"></div>
    </div>\
</div>

这样,就完美实现了宽高比16:9 的比例。
但是,这样做了之后,里面再放上图表,再浏览器窗口尺寸变化之后,浏览器重新计算尺寸时,渲染有些许卡顿,可能比较考验gpu性能吧。不清楚,昨天试的时候,有一点卡顿,刚刚又试了一下感觉还是挺流畅的。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342