美文网首页
前端笔记:图片按比例裁剪问题(转载记录)

前端笔记:图片按比例裁剪问题(转载记录)

作者: Utopi_a | 来源:发表于2015-08-09 20:36 被阅读431次

    最近在做一个产品列表页面,布局如右图所示。页面中有若干个 item,其中每个 item 都向左浮动,并包含在自适应浏览器窗口宽度的父元素中。

    效果图

    item 元素的 CSS 定义如下:

    .item{

            float:left;

            margin:10px2%;

            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:10px5%;

             padding-bottom:33.98%;

             width:21%;height:0;

    }

    相关文章

      网友评论

          本文标题:前端笔记:图片按比例裁剪问题(转载记录)

          本文链接:https://www.haomeiwen.com/subject/zrhiqttx.html