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

栏目: CSS · 发布时间: 5年前

内容简介:在开发过程中,会有这么一个情况,需要将一个盒子的尺寸定义为固定比例,且尺寸需根据视图的尺寸来进行缩放,也就是响应式,常见的多如有矩形、圆形等。下面我将使用下面的例子为大家进行讲解:其实实现这个效果,有多种方法,下面逐一介绍。

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

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

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

正文

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

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;
}
复制代码

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

榨干百度谷歌

榨干百度谷歌

张志 / 电子工业出版社 / 2011-1 / 28.00元

小小的搜索引擎,可以成为你从事网络营销的利器。如果你还没有意识到这一点,或者还不知道从何下手,请打开《榨干百度谷歌:搜索引擎广告大赢家》吧!《榨干百度谷歌:搜索引擎广告大赢家》作者将其丰富的实战经验融汇在这书中,结合大量国内不同行业实际应用案例,生动地告诉读者,怎样正确地利用搜索引擎,以很小的投资获得巨大的回报。并且深入浅出地介绍了企业开展搜索营销的关键点,包括如何提炼并组合关键词、如何撰写简洁明......一起来看看 《榨干百度谷歌》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换