码迷,mamicode.com
首页 > 其他好文 > 详细

弹性盒子布局解决不规则图片的等比例缩放的利器!

时间:2017-06-24 19:42:37      阅读:439      评论:0      收藏:0      [点我收藏+]

标签:pre   左右   class   table   img   blog   containe   宽高   container   

我们经常遇到这种需求:

在一个固定大小(固定比例)的容器里面展示图片,图片的大小比例都不是固定的,需要按容器的比例等比例缩图片上下左右居中显示。

技术分享

 

 

在没有弹性盒子布局的年代,额的做法:

1:水平居中,非常好解决,容器 text-align: center; 

2:垂直居中,容器display: table-cell; 图片vertical-align: middle;

3:等比例缩放,js解决,思路:

(1)如果图片宽高都没有超过容器大小,则忽略 

(2)如果图片的宽度或者高度其中有一方超过容器大小,则固定没超过的,缩放超过的

(3)如果图片宽度和高度都超过容器大小,则先缩放宽度到容器宽度,如果等比例缩放的高度没超过容器的高度则完美,如果超过则缩放高度到容器高度,再计算宽度。。。

炒鸡麻烦有木有!

而现在有了弹性盒子布局,零JS代码纯CSS实现以上效果,在弹性盒子布局里面,容器会自动判断子是否超过了大小,如果超过会自动按照以上规则进行缩放,什么水平居中垂直居中也是小case,简直爽到爆!

.container {
        display: -webkit-box;
        display: -webkit-flex;
        display: flex;
        -webkit-box-align: center;
        -webkit-align-items: center;
        align-items: center;
        -webkit-box-pack: center;
        -webkit-justify-content: center;
        justify-content: center;
        background: #000;
        img {
            width: 100%;
        }
    }

 

弹性盒子布局解决不规则图片的等比例缩放的利器!

标签:pre   左右   class   table   img   blog   containe   宽高   container   

原文地址:http://www.cnblogs.com/xxyzjb/p/7074138.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!