div css布局中对于图片列表或图片排版时,图片不是固定宽度高度大小,但图片占位是固定宽度高度,这个时候如果使用CSS固定死图片大小(宽度 高度),这个时候如果图片相对于这个位置不是等比例大小,那么这张图片就会变形,让图片变的不清晰,这个时候想让图片不变形又按比例缩放,如何解决?CSS图片缩小不变形,图片自动缩小,图片按比例等比例缩小不变形解决。
解决方法有两种:
第一种,让图片和布局宽度高度成等比例,这样CSS设置死宽度和高度,图片也是等比例缩小,图片也不会变形。
比如淘宝,要求店铺主上传产品封面图片是正方形的,为什么,因为图片宝贝展示列表都是正方形的排版布局,这样要求上传合适正方形宝贝封面图片,也是让图片不变形。
所以有条件的情况下,大家将首页、图片列表页的布局宽度高度保持一致,上传图片时候将图片先进行处理为布局宽度高度时等比例放大尺寸的。
第二种,使用CSS max-width和max-height实现图片自动等比例缩小
很简单我们要使用到max-width和max-height,这样即可设置对象图片最大宽度和最大高度,这样图片就会等比例缩放图片,然图片相对不变形清晰。
以下通过实例对比方法让大家掌握CSS控制图片缩小不变形技巧。
这里有个div,CSS宽度和CSS高度方便为300px和100px同时设置1px黑色边框,里面放了一张图片(图片原始宽度650px为高度为406px)。并通过CSS固定死图片宽度高度。
1、HTML源代码:
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>图片缩小不变形实例 www.divcss.com</title> <style> .divcss{ border:1px solid #000; width:300px; height:100px} .divcss img{width:300px; height:100px} </style> </head> <body> <div class="divcss"> <img src="img.jpg" /> </div> </body> </html>
2、CSS固定死图片宽度高度实例截图
原始图片展示:
原始图片截图
css固定宽度高度后变形的图片截图
3、小结,通过CSS固定对象内图片高度宽度,这样图片如果不是等比例缩小,那么图片就变形了。
二、CSS解决图片缩小不变形实例
使用max-width:300px或max-height:100px,即可解决图片比例缩小。但这样存在一个问题,如果按照宽度缩放,但图片过高会超出溢出盒子,这个时候需要对父级使用overflow:hidden隐藏超出图片内容。但是使用max-width或max-height,IE6不支持,我们需要设置个width:expression(this.width > 300 ? "300px" : this.width);或者height:expression(this.height>100?"100px":this.height);。
解决IE6支持max-height
div css解决IE6支持max-width
一般情况下只需要设置好宽度限制,比如这里只设置最大宽度为300px(max-width:300px),然后对父级使用overflow:hidden隐藏溢出图片,同时为了兼容IE6我们设置个width:expression(this.width > 300 ? "300px" : this.width);解决即可。
1、具体解决DIV+CSS实例代码如下:
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>图片缩小不变形实例 www.divcss.com</title> <style> .divcss{ border:1px solid #000; width:300px; height:100px;overflow:hidden} .divcss img{max-width:300px;_width:expression(this.width > 300 ? "300px" : this.width);} </style> </head> <body> <div class="divcss"> <img src="img.jpg" /> </div> </body> </html>
2、浏览器测试效果截图
css图片缩小等比例缩小后不变形截图
3、缺点介绍,如果使用此方法,兼容各大浏览器不变形,但图片不是完整显示的。