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%;
*/
}
这是平常的佩琪(假如图片比容器大的话,图片会超越容器)
.div1 {
width:500px;
height:400px;
border:1px solid black;
}
.div1 img {
width: 100%;
height:100%;
}
这是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 属性会失效.
这类结果就惬意多了
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>
固然末了还得看需求,产物是咋请求的。