国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

js驗證上傳圖片的方法

2024-05-06 16:20:01
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了js驗證上傳圖片的方法,可對上傳圖片的類型、大小等進行限制,非常簡單實用,需要的朋友可以參考下

本文實例講述了js驗證上傳圖片的方法。分享給大家供大家參考。具體實現方法如下:

 

 
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
  2. "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
  3. <html xmlns="http://www.w3.org/1999/xhtml"
  4. <head> 
  5. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
  6. <title>js驗證圖片</title> 
  7. <script> 
  8. UpLoadFileCheck=function() 
  9. {  
  10. this.AllowExt=".jpg,.gif"
  11. //允許上傳的文件類型 0為無限制 
  12. //每個擴展名后邊要加一個"," 小寫字母表示  
  13. this.AllowImgFileSize=0; 
  14. //允許上傳文件的大小 0為無限制 單位:KB  
  15. this.AllowImgWidth=0; 
  16. //允許上傳的圖片的寬度 0為無限制 單位:px(像素)  
  17. this.AllowImgHeight=0; 
  18. //允許上傳的圖片的高度 0為無限制 單位:px(像素)  
  19. this.ImgObj=new Image(); 
  20. this.ImgFileSize=0; 
  21. this.ImgWidth=0; 
  22. this.ImgHeight=0; 
  23. this.FileExt=""
  24. this.ErrMsg=""
  25. this.IsImg=false;//全局變量 
  26. UpLoadFileCheck.prototype.CheckExt=function(obj) 
  27. this.ErrMsg="";  
  28. this.ImgObj.src=obj.value;  
  29. //this.HasChecked=false;  
  30. if(obj.value==""
  31. this.ErrMsg="/n請選擇一個文件";  
  32. else 
  33. {  
  34. this.FileExt=obj.value.substr(obj.value.lastIndexOf(".")).toLowerCase();  
  35. if(this.AllowExt!=0&&this.AllowExt.indexOf(this.FileExt)==-1) 
  36. //判斷文件類型是否允許上傳  
  37. {  
  38. this.ErrMsg="/n該文件類型不允許上傳。請上傳 "+this.AllowExt+" 類型的文件,當前文件類型為"+this.FileExt;  
  39. }  
  40. if(this.ErrMsg!="")  
  41. this.ShowMsg(this.ErrMsg,false);  
  42. return false
  43. else 
  44. return this.CheckProperty(obj);  
  45. UpLoadFileCheck.prototype.CheckProperty=function(obj) 
  46. if(this.ImgObj.readyState!="complete")// 
  47. {  
  48. sleep(1000);//一秒使用圖能完全加載  
  49. }  
  50. if(this.IsImg==true
  51. this.ImgWidth=this.ImgObj.width; 
  52. //取得圖片的寬度  
  53. this.ImgHeight=this.ImgObj.height; 
  54. //取得圖片的高度 
  55. if(this.AllowImgWidth!=0&&this.AllowImgWidth<this.ImgWidth)  
  56. this.ErrMsg=this.ErrMsg+"/n圖片寬度超過限制。請上傳寬度小于"+this.AllowImgWidth+"px的文件,當前圖片寬度為"+this.ImgWidth+"px";  
  57. if(this.AllowImgHeight!=0&&this.AllowImgHeight<this.ImgHeight)  
  58. this.ErrMsg=this.ErrMsg+"/n圖片高度超過限制。請上傳高度小于"+this.AllowImgHeight+"px的文件,當前圖片高度為"+this.ImgHeight+"px";  
  59. this.ImgFileSize=Math.round(this.ImgObj.fileSize/1024*100)/100; 
  60. //取得圖片文件的大小  
  61. if(this.AllowImgFileSize!=0&&this.AllowImgFileSize<this.ImgFileSize)  
  62. this.ErrMsg=this.ErrMsg+"/n文件大小超過限制。請上傳小于"+this.AllowImgFileSize+"KB的文件,當前文件大小為"+this.ImgFileSize+"KB";  
  63. if(this.ErrMsg!="")  
  64. this.ShowMsg(this.ErrMsg,false);  
  65. return false
  66. else 
  67. return true;  
  68. }  
  69. UpLoadFileCheck.prototype.ShowMsg=function(msg,tf) 
  70. //顯示提示信息 tf=false 顯示錯誤信息 msg-信息內容  
  71. {  
  72. /*msg=msg.replace("/n","<li>");  
  73. msg=msg.replace(//n/gi,"<li>");  
  74. */ 
  75. alert(msg); 
  76. function sleep(num)  
  77. {  
  78. var tempDate=new Date();  
  79. var tempStr="";  
  80. var theXmlHttp = new ActiveXObject( "Microsoft.XMLHTTP" );  
  81. while((new Date()-tempDate)<num )  
  82. {  
  83. tempStr+="/n"+(new Date()-tempDate);  
  84. try{  
  85. theXmlHttp .open( "get""about:blank?JK="+Math.random(), false );  
  86. theXmlHttp .send();  
  87. }  
  88. catch(e){;}  
  89. }  
  90. //containerDiv.innerText=tempStr;  
  91. return;  
  92. }  
  93. function c(obj) 
  94. var d=new UpLoadFileCheck();  
  95. d.IsImg=true
  96. d.AllowImgFileSize=100; 
  97. d.CheckExt(obj) 
  98. </script> 
  99. </head> 
  100. <body> 
  101. <input name="" type="file" onchange="c(this)"/> 
  102. </body> 
  103. </html> 

希望本文所述對大家的javascript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 万荣县| 晋中市| 东台市| 资源县| 浦江县| 耿马| 海南省| 安国市| 夏邑县| 育儿| 东源县| 那曲县| 贵溪市| 鲁甸县| 聂拉木县| 沙雅县| 紫金县| 阳泉市| 长治市| 邵东县| 揭东县| 响水县| 金阳县| 大庆市| 贡嘎县| 永宁县| 诏安县| 牟定县| 万宁市| 乐陵市| 咸阳市| 三台县| 定南县| 文登市| 磐安县| 平远县| 成都市| 临潭县| 泰和县| 博白县| 石泉县|