首页 > 语言 > JavaScript > 正文

图片自动缩放 js图片缩放

2024-05-06 16:09:23
字体:
来源:转载
供稿:网友
图片自动缩放 js图片缩放

对于不指定大小的图片默认是以原大小显示,所以在不指定大小的图片上用onload事件触发脚本代码,在代码中判断图片的尺寸,如果超过指定值,将自动设置为允许的最大值。

具体步骤:
方法一:在图片加载完毕后用onload句柄触发执行脚本,重设图片的宽度为图片宽度和300两者的最小值。
代码示例: <img src="demo.gif" onload="if(this.width>300)this.width=300">
或者
<img src="demo.gif" onload="this.width=Math.min(this.width,300)">

方法二:按比例缩小。只需要把js加在head之间,再在body处加入onload="ResizeImages();"代码。
  1. <script language="JavaScript"
  2. <!-- 
  3. function ResizeImages() 
  4. var myimg,oldwidth; 
  5. var maxwidth=180; //缩放系数 
  6. for(i=0;i <document.images.length;i++){ 
  7. myimg = document.images[i]; 
  8. if(myimg.width > maxwidth) 
  9. oldwidth = myimg.width; 
  10. myimg.width = maxwidth; 
  11. myimg.height = myimg.height * (maxwidth/oldwidth); 
  12. //--> 
  13. </script> 
  14.  
  15. 或 
  16.  
  17. <script language="JavaScript"
  18. <!-- 
  19. //图片按比例缩放 
  20. var flag=false
  21. function DrawImage(ImgD,iwidth,iheight){ 
  22. //参数(图片,允许的宽度,允许的高度) 
  23. var image=new Image(); 
  24. image.src=ImgD.src; 
  25. if(image.width>0 && image.height>0){ 
  26. flag=true
  27. if(image.width/image.height>= iwidth/iheight){ 
  28. if(image.width>iwidth){ 
  29. ImgD.width=iwidth; 
  30. ImgD.height=(image.height*iwidth)/image.width; 
  31. }else
  32. ImgD.width=image.width; 
  33. ImgD.height=image.height; 
  34. ImgD.alt=image.width+"×"+image.height; 
  35. else
  36. if(image.height>iheight){ 
  37. ImgD.height=iheight; 
  38. ImgD.width=(image.width*iheight)/image.height; 
  39. }else
  40. ImgD.width=image.width; 
  41. ImgD.height=image.height; 
  42. ImgD.alt=image.width+"×"+image.height; 
  43. //--> 
  44. </script> 


调用:<img src="images/toplogo.gif" onload="javascript:DrawImage(this,100,100)">
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选