html页面宽高比例,CSS之宽高比例布局的方法示例

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

什么是宽高比?

宽高比也称纵横比,元素的纵横比描述了其宽度和高度之间的比例关系。两种常见的视频宽高比为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节点少、可响应式、需精确到像素

.aspect-ration { background-color: #f00; }

.aspect-ration::before {

content: "";

float: left;

padding-bottom: 50%;

}

.aspect-ration::after {

clear: both;

content: "";

display: table;

}

2、内容绝对定位

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

.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节点少、可响应式

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之居中布局

参考

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
网站的设计通常涉及到 HTMLCSSHTML(超文本标记语言)用于定义网页的结构和内容,而CSS(层叠样式表)用于控制网页的样式和布局。 在设计一个网站时,首先需要编写 HTML 代码来构建网页的结构。HTML 使用标签来定义标题、段落、链接、图像等元素,并使用嵌套的方式来组织页面内容。例如,使用 `<h1>` 标签来定义一个一级标题,使用 `<p>` 标签来定义一个段落。 然后,使用 CSS 来为网页添加样式。CSS 使用选择器来选中特定的 HTML 元素,并定义它们的样式属性。例如,使用 `h1` 选择器来选中所有的一级标题,并设置它们的字体大小和颜色。 以下是一个简单的示例,展示了如何使用 HTMLCSS 来设计一个基本的网页: HTML 代码: ```html <!DOCTYPE html> <html> <head> <title>我的网页</title> <link rel="stylesheet" type="text/css" href="styles.css"> </head> <body> <h1>欢迎来到我的网页</h1> <p>这是一个示例网页。</p> <img src="image.jpg" alt="图片"> </body> </html> ``` CSS 代码(存储在名为 "styles.css" 的文件中): ```css h1 { color: blue; font-size: 24px; } p { color: gray; font-size: 16px; } img { width: 200px; height: auto; } ``` 上述示例中,`<h1>` 元素的文本颜色为蓝色,字体大小为 24 像素;`<p>` 元素的文本颜色为灰色,字体大小为 16 像素;`<img>` 元素的度为 200 像素,度会根据比例自动调整。 当 HTMLCSS 文件链接在一起后,浏览器会根据 HTML 结构和 CSS 样式来渲染网页并呈现给用户。这样就实现了网站的基本设计。当然,在实际开发中,还会涉及到更多的 HTML 标签和 CSS 属性,以达到更复杂和丰富的设计效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值