css完成图片自适应容器的几种体式格局

css完成图片自顺应容器

常常有如许一个场景,需要让图片自顺应容器的大小。

1、img标签的体式格局

我们立时就可以想到,把width、height 设置为100%啊。来看一哈结果。

<div class='div1'>
    <img src="./peiqi.png" alt="">
</div>
.div1 {
    width:500px;
    height:400px;
    border:1px solid black;
}
.div1 img  {
    /*
    width: 100%;
    height:100%;
    */
}

《css完成图片自适应容器的几种体式格局》
这是平常的佩琪(假如图片比容器大的话,图片会超越容器)

.div1 {
    width:500px;
    height:400px;
    border:1px solid black;
}
.div1 img  {
    width: 100%;
    height:100%;
}

《css完成图片自适应容器的几种体式格局》
这是100%的佩琪

额,彷佛刚过完年。

虽然相符了自顺应的请求,然则如图所见图片失真了。这类图片比容器小的状况强即将图片自顺应的话图片就失真。假如说是单个图片(logo、占位图、等)按设想稿开辟就可以够了。但常常会碰到接口猎取的不规则图片的状况,平常这类时刻会将小于容器的话将其程度、垂直居中。
整顿一下使命:

  • 图片宽高都小于容器时垂直、程度居中
  • 图片宽高都大于容器时坚持宽高比将width或height充溢容器
    <div class='div1'>
        <img src="./peiqi.png" alt="">
    </div>
    <div class='div1'>
        <img src="./peiqi2.png" alt="">
    </div>
    <div class='div1'>
        <img src="./peiqi4.jpeg" alt="">
    </div>

    .div1 {
        width:500px;
        height:400px;
        border:1px solid black;
        display: table-cell;
        vertical-align: middle;
    }
    .div1 img  {
        max-width: 100%;
        max-height: 100%;
        display: block;
        margin: auto;
    }

max-height 这个属性会阻挠 height 属性的设置值变得比 max-height 更大。

max-height 属性用来设置给定元素的最大高度. 假如height 属性设置的高度比该属性设置的高度还大,则height 属性会失效.

《css完成图片自适应容器的几种体式格局》
这类结果就惬意多了

2、背景图的体式格局

    .div {
        background-size: contain;
    }

background-size: contain; 把图象图象扩大至最大尺寸,以使其宽度和高度完整顺应内容地区。

应用css的 background-size: contain; 属性就可以进一步优化图片的宽高都小于容器的状况了。

上代码

    div {
        height: 400px;
        width: 500px;
        border: 1px solid black;
        background-repeat: no-repeat;
        background-size: contain;
        background-position: center;
    }
    .div1 {
        background-image: url(./peiqi1.png);
    }
    .div2 {
        background-image: url(./peiqi2.png);
    }
    .div3 {
        background-image: url(./peiqi4.jpeg);
    }
    <div class='div1'></div>
    <div class='div2'></div>
    <div class='div3'></div>

《css完成图片自适应容器的几种体式格局》

固然末了还得看需求,产物是咋请求的。

    原文作者:飘啊飘
    原文地址: https://segmentfault.com/a/1190000018279674
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞