CSS之宽高占比合理布局的方式示例

2021-01-20 17:47 jianzhan

在一些特殊的情景中,如视頻播发、可视性化图表占位等1些高宽必须固定不动的占比。假如占位区段是由固定不动值明确,那末大家皆大欢喜2,但在现阶段的的运用发展趋势中宽高自融入的方法才可以考虑大家的要求,那末大家该怎样这类自融入的 宽高比合理布局 呢?

甚么是宽高比?

宽高比也称横纵比,元素的横纵比叙述了其宽度和高宽比之间的占比关联。两种普遍的视頻宽高比为4:3和16:9。要维持div的宽高比,根据为 padding-top / padding-bottom 加上1个百分比值。不一样的宽高比具备不一样的百分比值。或选用视窗企业 vw / vh 设定相应高宽。在其中1些以下所示:

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来测算,运用这1特性大家能够根据设定 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

运用视窗企业是1种相对显示屏尺寸的测算方法,同理大家也也能用用 rem 来做到同样的实际效果。实际完成与视窗企业1样。

可用情景: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() 能够动态性测算相应值,大家只必须了解相应比值与高宽中1个值,该方法还可以沿用到padding兼容中。

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

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

以上两种方式4种完成方法可依据不一样情景采用不一样的方法。但是有一部分状况下选用padding与伪元素的方法相对性更佳。

融合垂直居中

在些基本上,大家将会会涉及到有关的对宽高比元素开展垂直居中排版,有关细节可参照我上篇文章内容CSS之垂直居中合理布局

参照

Aspect Ratio Boxes

Maintain the aspect ratio of a div with CSS

Padding

The-padding

以上便是本文的所有內容,期待对大伙儿的学习培训有一定的协助,也期待大伙儿多多适用脚本制作之家。