利用padding百分比继承父级元素宽度特性实现元素宽高比例缩放
来源:互联网 发布:seed软件 编辑:程序博客网 时间:2024/06/10 04:51
纯 CSS 实现高度与宽度成比例的效果
最近在做一个产品列表页面,布局如下图所示。页面中有若干个 item,其中每个 item 都向左浮动,并包含在自适应浏览器窗口宽度的父元素中。
item 元素的 CSS 定义如下:
.item { float: left; margin: 10px 2%; width: 21%;}
这时遇到的一个需求:在保持 item 元素宽高比恒定(如高是宽的 1.618 倍)的情况下,使得 item 元素可以和父元素同比缩放。 我们知道,如果当 item 元素是图片,同时需要保持的宽高比恰好为图片本身的宽高比时,可以设置 item 的 height 为 auto 即可轻松实现这个需求。然而当 item 元素不是图片或者要保持的宽高比和图片本身的宽高比不同时,这个需求显得很难直接用 CSS 实现。
为此我放弃 CSS,直接用 JavaScript 绑定 window 的 onresize 事件来动态获取每个 item 的宽度,从而计算并设置其高度。
我一直在使用这个解决方案,直到今天调整样式时,突然想到这个需求竟然是可以只使用 CSS 解决的。
首先需要知道,一个元素的 padding,如果值是一个百分比,那这个百分比是相对于其父元素的宽度而言的,即使对于 padding-bottom 和 padding-top 也是如此。
另外,在计算 Overflow 时,是将元素的内容区域(即 width / height 对应的区域)和 Padding 区域一起计算的。换句话说,即使将元素的 overflow 设置为 hidden,“溢出”到 Padding 区域的内容也会照常显示。
综上两条所述,我们可以使用 padding-bottom 来代替 height 来实现高度与宽度成比例的效果。因为 item 元素的宽度是其父元素宽度的 21%,所以我们将 padding-bottom 设置为它的 1.618 倍,即 33.98%。同时将其 height 设置为 0 以使元素的“高度”等于 padding-bottom 的值,从而实现需要的效果。
最后 item 元素的 CSS 样式为:
.item { float: left; margin: 10px 5%; padding-bottom: 33.98%; width: 21%; height: 0;}
页面效果见 http://jsfiddle.net/luin/25BbH/7/,拖动窗口调整页面宽度,item 元素始终保持恒定的宽高比。
- 利用padding百分比继承父级元素宽度特性实现元素宽高比例缩放
- padding-top的值用的是百分比,实际显示的不是父元素高度的百分比,而是宽度的百分比!margin-top同理
- 元素宽度的最大百分比
- 可以设置宽高比,宽度确定,高度比例缩放的ImageView快速实现
- 居中百分比宽高的元素
- absolute 元素的百分比宽高
- 元素marign与padding的百分比设置
- 行内元素padding-left用百分比
- 谈谈padding对块级元素宽度的影响
- 让子元素的宽高随着父元素的宽高缩放
- 不让padding影响元素的宽度
- 利用Overflow:Hidden实现自适应左右两列布局/填充父级元素剩余宽度
- CSS百分比padding实现比例固定图片自适应布局
- zoom元素用来设置缩放比例的
- 父元素为一个div,宽度高度不固定,子元素是一个块状元素,宽高已知,如何实现子元素在父元素内水平、垂直居中?
- Windows Phone 8.1中元素适应屏幕宽度或子元素继承父元素宽度的解决方案
- css 行内元素 块元素 替换元素 非替换元素 以及这些元素的width height margin padding 特性
- img的宽高无法根据父a元素变化-----内联元素化为块级元素
- 实验2:1
- 2020.绝对值排序
- Oracle彻底删除
- 容斥 + 组合数学 ---Codeforces Round #317 A. Lengthening Sticks
- 扩展KMP
- 利用padding百分比继承父级元素宽度特性实现元素宽高比例缩放
- 数论 + 公式
- 概率dp
- Trie树 + DFS
- 0.C语言概述
- 后缀数组LCP + 二分
- 数学
- 构造
- 特征根法求通项+广义Fibonacci数列找循环节