在Web上显示图片,通常都会有图片显示比例问题,如果不给<img />限制width和height,那么如果图片大了就会将整个页面挤乱,图片小了又会使图片失真。
????我的需求如下:
????????1、预先定义好图片显示的标准宽度和高度。
????????2、如果图片的大小超过了标准定义,那么等比例压缩图片。
????????3、如果图片的大小等于标准定义,那么按照标准宽度和高度显示图片。
????????4、如果图片的大小小于标准定义,那么不对图片进行任何压缩处理。
?
JavaScript代码
- function?DrawImage(ImgD,iwidth,iheight){ ??
- ????//参数(图片,允许的宽度,允许的高度) ??
- ????var?image=new?Image(); ??
- ????image.src=ImgD.src; ??
- ????if(image.width>0?&&?image.height>0){ ??
- ??????if(image.width/image.height>=?iwidth/iheight){ ??
- ??????????if(image.width>iwidth){?? ??
- ??????????????ImgD.width=iwidth; ??
- ??????????????ImgD.height=(image.height*iwidth)/image.width; ??
- ??????????}else{ ??
- ??????????????ImgD.width=image.width;?? ??
- ??????????????ImgD.height=image.height; ??
- ??????????} ??
- ??????}else{ ??
- ??????????if(image.height>iheight){?? ??
- ??????????????ImgD.height=iheight; ??
- ??????????????ImgD.width=(image.width*iheight)/image.height;???????? ??
- ??????????}else{ ??
- ??????????????ImgD.width=image.width;?? ??
- ??????????????ImgD.height=image.height; ??
- ??????????} ??
- ??????} ??
- ????} ??
- }??
调用:<img?src=”images/toplogo.gif”?onload=”javascript:DrawImage(this,100,100)”>
如果图片较大,建议在图片标签里面同时设置期望的图片大小,这样不会导致页面在加载中撑开,该大小不会影响最终缩放效果。可以修改上面的代码为:
<img src=”/images/NullPic.gif” alt=”自动缩放后的效果” width=”200″ height=”200″?onload=”javascript:DrawImage(this,100,100)”?/>
最新评论
写的挺好的
有没有兴趣翻译 impatient js? https://exploringjs.com/impatient-js/index.html
Flexbox playground is so great!
感谢总结。
awesome!
这个好像很早就看到类似的文章了
比其他的教程好太多了
柯理化讲的好模糊…没懂