在对图片根据一定的规则进行宽高的设置

1.有这样一个问题 因为用户上传的图片大小是不确定的 但是可显示的范围是300*60px;所以对其图片进行设置 如果宽大于300px 让其显示最大 高自适应 如果高大于60px; 高显示60px; 宽自适应。因为这种都是在图片加载完成后进行判断的 总是会感觉页面有抖动。 有什么解决方法吗?

蛊毒传说
浏览 651回答 1
1回答

慕尼黑5688855

我之前的项目中有遇到相同的问题,我的建议如下:1、给你的img设置样式max-width:300px;max-height:60px;父容器宽高固定,如下<div style="position:relative;width: 300px;height: 60px;">&nbsp; <img src="xxx" alt="" style="position:absolute;top:50%;left:50%;transform: translate(-50%,-50%);max-width: 300px;max-height: 60px;"></div>这样设置后,不会出现抖动,比较简单;但是有个问题:即用户上传的图片尺寸小于这个范围的话,图片并不能放大铺满这个范围2、先用默认图片代替或先隐藏,等图片加载完,根据图片的具体尺寸设置样式后再替换或者显示var img = new Image().src='xxx';img.onload = function() {&nbsp; &nbsp; var suit = 'width',&nbsp; &nbsp; &nbsp; &nbsp; w = img.width,&nbsp; &nbsp; &nbsp; &nbsp; h = img.height;&nbsp; &nbsp; if (w/h < 300/60) {&nbsp; &nbsp; &nbsp; suit = 'height';&nbsp; &nbsp; }&nbsp; &nbsp; ...&nbsp; }
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript