CSS题目系列(2) - 实现一个固定比例盒子

描述

在开发过程中,会有这么一个情况,需要将一个盒子的尺寸定义为固定比例,且尺寸需根据视图的尺寸来进行缩放,也就是响应式,常见的多如有矩形、圆形等。

下面我将使用下面的例子为大家进行讲解:

image

正文

其实实现这个效果,有多种方法,下面逐一介绍。

1、垂直方向的padding

相信大家对padding都不陌生,但你知道他是如何取值的吗?

看一下MDN中对padding给出的解释:

取值

指定一个,两个,三个或四个下列的值:

  • <长度>

    可指定非负的固定宽度. See <length> for details

  • <百分比>

    相对于包含块的宽度

  • 指定一个值时 该值指定四个边的内边距

  • 指定两个值时 第一个值指定上下两边的内边距 第二个指定左右两边的内边距

  • 指定三个值时 第一个指定上边的内边距 .第二个指定左右两边 第三个指定下边

  • 指定四个值时分别为上 右 下 左(顺时针顺序)

也就是说,padding的值设定为百分比时,将根据父容器的宽度来计算。

现在假设我们有一个div,我们希望它的尺寸能根据body(它的父容器)的宽度来实现固定比例:

<div class="box"></div>

样式部分

.box{
    width:50%;
    padding-bottom:50%;
}

其实这里的padding-bottom换成padding-top也一样可以实现。

没错,就这么简单,我们已经实现了文章开头所展示的效果。

但是我们使用这种方法的时候需要注意几点:

  1. 不需要设定height,最好就是手动设定为0
  2. 子元素需要设定为绝对定位(父容器为相对定位),否则子元素将被padding挤出去。

其它比例

前面实现的是一个正方形比例的,那如果我想要是16:9的呢?

那我们将根据一个公式:width * x / y计算,如下:

.box{
    width:50%;
    padding-bottom: calc( 50% * 9 / 16 );
    /* 或者 */
    padding-bottom : 28.125%;
}

2、视窗单位

视窗是你的浏览器实际显示内容的区域——换句话说是你的不包括工具栏和按钮的网页浏览器。这些单位是vw,vh,vminvmax。它们都代表了浏览器(视窗)尺寸的比例和窗口大小调整产生的规模改变。

也就是说,网页的宽度是100vw,取一半就是50vw,无论怎么缩放都是一半,而且这个一半不止可以用在width上。

所以:

<div class="box"></div>
.box{
    width:50vw;
    height:50vw;
}

一个正方形就出来了,简单吗???

其它比例

跟上面一样,通过公式可以得到:

.box{
    width:50vw;
    padding-bottom: calc( 50vw * 9 / 16 );
    /* 或者 */
    padding-bottom : 28.125vw;
}

参考链接

结束语

通过以上两种方法,以后实现固定比例的盒子是不是变得简单起来了?

注:此文为原创文章,如需转载,请注明出处。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 14,680评论 1 92
  • 所有题目答案整理自网络,如有错误,接受指正,拒绝批评! 关于html5 HTML5的十大新特性 语义化标签使得页面...
    黄金原野阅读 5,319评论 0 0
  • 响应式布局的常用解决方案对比(媒体查询、百分比、rem和vw/vh) 本文介绍在布局中常用的单位,比如px、%、r...
    一片空白1233阅读 24,112评论 1 31
  • 今天去电影院看电影了。感谢老总給我们的机会…… 人生中第一次去电影院看电影给我的感觉超好。 以下是我的观后感,分享...
    羊小女阅读 2,498评论 0 0
  • 我的耳机坏了,是右边的。 其实坏不坏都无所谓,反正还有左边嘛,如果听不惯的话就再买一条呗,不想再买一条的话就不要用...
    慵懒小兽阅读 2,481评论 0 1