用CSS解决前端图片变形问题

一、让图片的宽度或者高度等于容器的宽度或高度,多余的裁掉,然后让图片居中:

<style type="text/css">
div{
	width: 200px;
	height: 200px;
	overflow: hidden;
	border: 2px solid red;
	position: relative;
}
img{
	width: 100%;
	position: absolute;
 top: 50%;
 left: 50%;
 transform: translate(-50%, -50%); 
}
</style>
<div>
	<img src="1.png">
</div>
<br>
<div>
	<img src="1.jpg">
</div>

效果图如下:

看了这个终于可以利用CSS完美解决前端图片变形问题

css设置图片

如果图片的宽度限制了,高度大于等于容器的高度,就会填满整个容器,但是如果图片高度小于容器高度,就会出现空白,固定高度同理。此方法是最简单也最实用,配合后台裁切,更加完美。

二、让图片始终显示在容器内,并且居中显示。这种方法不会裁切图片,可以说是上面的升级版。

<style type="text/css">
div{
	width: 200px;
	height: 200px;
	border: 2px solid red;
	position: relative;
}
img{
	max-width: 100%;
	max-height: 100%;
	position: absolute;
 top: 50%;
 left: 50%;
 transform: translate(-50%, -50%); 
}
</style>
<div>
	<img src="1.png">
</div>
<br>
<div>
	<img src="1.jpg">
</div>

效果图如下:

看了这个终于可以利用CSS完美解决前端图片变形问题

max-width控制图片

可以看到,无论是宽度超过容器,还是高度超过容器,还是宽高都不超过容器,都能全部居中显示在容器内,不会裁切。

此外,借助JS也能实现这种效果:即当图片的宽度大于高度,则设置图片的宽度为100%,如果图片的高度大于宽度,则设置高度为100%,这里仅仅进行讨论,实战中,并不使用这种方法(能用css实现的,就不要用js了嘛)。为了方便,这里借助了jQuery,记得引入jQuery哦!

<style>
div{
	width: 200px;
	height: 200px;
	border: 2px solid red;
	position: relative;
}
img{
	position: absolute;
 top: 50%;
 left: 50%;
 transform: translate(-50%, -50%); 
}
</style>
<div>
	<img src="1.png">
</div>
<br>
<div>
	<img src="1.jpg">
</div>
<script type="text/javascript">
	//一定要等图片加载完再进行计算
	window.onload = function(){
		$('img').each(function(){
			var _w = $(this).width();
			var _h = $(this).height();
			if(_w > _h){
				$(this).css('width','100%');
			}else{
				$(this).css('height','100%');
			}
		})
	}
</script>

三、将图片变成背景,通过改变背景尺寸等可以任意改变图片在容器中显示的效果,操作是最方便的:

<style type="text/css">
div{
	width: 200px;
	height: 200px;
	border: 2px solid red;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
</style>
<div style="background-image: url(1.jpg);"></div>

效果图如下:

看了这个终于可以利用CSS完美解决前端图片变形问题

css背景图片控制

通过上图更改background-size,我们可以看到方法一和方法二都能轻松实现。而且,最后一种cover效果是最理想的,即居中显示,占满整个容器并且不变形。这种方法如果不考虑seo的话,用起来还是很顺手的。但是,如果您是资讯站、图片展等等,千万不要用这种方法,否则你的图片将很难被搜索引擎收录。

四、如果有什么方法,即能实现第三种方法的效果,又能兼顾SEO就好了。这里就要隆重推出:object-fit和object-position。你可以这么理解,object-position相当于background-position,它的默认值是50% 50%,也就是居中,所以一般不写,加了object-fit,默认就居中了。而object-fit,相当于background-size,即图片填充方式(这里不是图片大小)。

<style type="text/css">
div{
	width: 200px;
	height: 200px;
	border: 2px solid red;
}
img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}
</style>
<div>
	<img src="1.jpg">
</div>

效果图如下:

看了这个终于可以利用CSS完美解决前端图片变形问题

object-fit控制图片显示

注意:图片一定要设置宽高,否则设置object-fit无效。将图片设置为何容器一样的宽高就可以了。容器也不需要设置溢出隐藏,object-fit会自动隐藏超出图片的宽高部分。

  • 7
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值