200字范文,内容丰富有趣,生活中的好帮手!
200字范文 > css实现宽高比固定

css实现宽高比固定

时间:2024-04-07 01:06:44

相关推荐

css实现宽高比固定

在保持 item 元素宽高比恒定(如高是宽的 1.5 倍)的情况下,使得 item 元素可以和父元素同比缩放。我们知道,如果当 item 元素是图片,同时需要保持的宽高比恰好为图片本身的宽高比时,可以设置 item 的heightauto即可轻松实现这个需求。然而当 item 元素不是图片或者要保持的宽高比和图片本身的宽高比不同(图片规格不统一)时,item 出现凌乱的感觉这个需求显得很难直接用 CSS 实现。

首先需要知道,一个元素的padding,如果值是一个百分比,那这个百分比是相对于其父元素的宽度而言的,即使对于padding-bottompadding-top也是如此。

另外,在计算 Overflow 时,是将元素的内容区域(即width/height对应的区域)和 Padding 区域一起计算的。换句话说,即使将元素的overflow设置为hidden,“溢出”到 Padding 区域的内容也会照常显示。

综上两条所述,我们可以使用padding-bottom来代替height来实现高度与宽度成比例的效果。因为 item 元素的宽度是其父元素宽度的 100%,所以我们将padding-bottom设置为它的 1.5倍,即 67%。同时将其height设置为0以使元素的“高度”等于padding-bottom的值,从而实现需要的效果。

最后 item 元素的 CSS 样式为:

.project-img {position: relative;width: 100%;height: 0;padding-top: 67%;font-size: 0;border: 1px solid rgba(255, 255, 255, 0.1);.logo_url{position: absolute;top: 0;left: 0;width: 100%;height: 100%;object-fit: cover;margin: 0 auto;}}

注意:padding-bottom是按照父元素的宽度比计算的,而不是按高度算,所以这里可以用溢出的padding-bottom来做(padding-top也可以)

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。