CSS之宽高比例布局的方法示例

所属分类: 网页制作 / CSS 阅读数: 899
收藏 0 赞 0 分享

在某些特定的场景中,如视频播放、可视化图表占位等一些高宽需要固定的比例。如果占位区间是由固定值确定,那么我们皆大欢喜,但在目前的的应用发展中宽高自适应的方式才能满足我们的需求,那么我们该如何这种自适应的 宽高比布局 呢?

什么是宽高比?

宽高比也称纵横比,元素的纵横比描述了其宽度和高度之间的比例关系。两种常见的视频宽高比为4:3和16:9。要保持div的宽高比,通过为 padding-top / padding-bottom 添加一个百分比值。不同的宽高比具有不同的百分比值。或采用视窗单位 vw / vh 设置相应高宽。其中一些如下所示:

aspect ratio padding-bottom/top value vw/vh(width|height)
16:9 56.25% 100vw | 56.25vw
4:3 75% 100vw | 75vw
3:2 66.66% 100vw | 66.66vw
8:5 62.5% 100vw | 62.5vw
2:1 50% 100vw | 50vw

利用padding-top/bottom适配

在CSS中 margin 与 padding 的百分比值是根据容器的width来计算,利用这一性质我们可以通过设置 padding-top/bottom 的百分比值实现。 采用这种方法,需要把容器的height设置为0,最终容器实际高度由padding撑出。在此基础上又可分为 伪元素 与 内容绝对定位 两种方案。这也是目前最佳的处理方式。具体实现如下:

Note: 示例均采用2:1的关系

1、伪元素

适用场景:IE8+ 、现代浏览器

优点: DOM节点少、可响应式、需精确到像素

<div class="aspect-ration"></div>
.aspect-ration { background-color: #f00; }
  .aspect-ration::before {
    content: "";
    float: left;
    padding-bottom: 50%;
  }
 .aspect-ration::after {
    clear: both;
    content: "";
    display: table;
  }

2、内容绝对定位

适用场景:IE8+ 、现代浏览器 优点: 可响应式、精确到像素

<div class="aspect-ration">
    <div class="content"></div>
  </div>

.aspect-ratio {
  height: 0;
  overflow: hidden;
  padding-top: 50%;
  background: #f00;
  position: relative;
}
.content {
  position: absolute; top: 0; left: 0; right: 0; bottom: 0;
  /* 或者 */
  /* position: absolute; top: 0; left: 0; width: 100%; height: 100%; */
}

视窗单位 vw/vh

利用视窗单位是一种相对于屏幕大小的计算方式,同理我们也也可用用 rem 来达到相同的效果。具体实现与视窗单位一样。

适用场景:IE10+ 、现代浏览器

优点: DOM节点少、可响应式

<div class="aspect-ratio"></div>

1、固定值

值的计算可参考文章头部表格

/* vw */
.aspect-ratio{ width: 100vw; height: 50vw; }

/*vh */
.aspect-ratio{ width: 100vh; height: 50vh; }

2、calc()

利用 calc() 可以动态计算相应值,我们只需要知晓相应比值与高宽中一个值,该方式也可以延用到padding适配中。

/* vw */
.aspect-ratio{ width: 100vw; height: calc(100vw * 1 / 2); }

/*vh */
.aspect-ratio{ width: 100vh; height: calc(100vw * 1 / 2); }

以上两种方法四种实现方式可根据不同场景选用不同的方式。不过有部分情况下采用padding与伪元素的方式相对更佳。

结合居中

在些基础上,我们可能会涉及相关的对宽高比元素进行居中排版,相关细节可参考我上篇文章CSS之居中布局

参考

Aspect Ratio Boxes

Maintain the aspect ratio of a div with CSS

Padding

The-padding

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

更多精彩内容其他人还在看

CSS圆角边框制作指南与实例

这篇文章主要介绍了CSS圆角边框制作指南与实例,这里突出讲解了以纯代码实现的小圆角 来消灭锯齿的方法,需要的朋友可以参考下
收藏 0 赞 0 分享

css实现移动端图片文字水平居中

这篇文章主要为大家详细介绍了css实现移动端图片文字水平居中的方法,如何实现图片以及文字的整体水平居中,本文为大家提供两种解决办法,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Div+CSS对HTML的table表格定位用法实例

这篇文章主要介绍了Div+CSS对HTML的table表格定位用法实例,文中讲到了CSS的定位差异问题需要的朋友可以参考下
收藏 0 赞 0 分享

使用div+CSS将页脚始终控制在页面最下方的方法

这篇文章主要介绍了使用div+CSS将页脚始终控制在页面最下方的方法,文中介绍了设置container以及使用绝对定位两种方法来解决,需要的朋友可以参考下
收藏 0 赞 0 分享

你值得拥有的CSS下拉菜单效果

这篇文章主要介绍了你值得拥有的多种CSS下拉菜单效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

CSS利用伪元素实现导航栏斜线分隔

这篇文章主要介绍了CSS利用伪元素实现导航栏斜线分隔的相关资料
收藏 0 赞 0 分享

纯CSS3打造属于自己的“小黄人”

这篇文章主要为大家详细介绍了纯CSS3打造属于自己的“小黄人”的相关代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

浅谈各种浏览器下的CSS Hack兼容性写法

这篇文章主要介绍了各种浏览器下的CSS Hack兼容性写法,CSS Hack大致可以分为内部Hack和选择器Hack以及HTML头部引用Hack,需要的朋友可以参考下
收藏 0 赞 0 分享

学习DIV+CSS网页布局之一列布局

学习DIV+CSS网页布局中的一列布局,本文为大家分享的是DIV+CSS网页布局教程的第一篇,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

学习DIV+CSS网页布局之两列布局

学习DIV+CSS网页布局中的两列布局,本文为大家分享的是DIV+CSS网页布局教程的第二篇,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享
查看更多