javascript图片上传格式尺寸等特征验证效果
分类:实例代码
本章节分享一段代码实例,它实现了验证图片上传格式或者尺寸等特性的功能。
代码实例如下:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="author" content="http://www.pipipi.net/" /> <title>前端教程网</title> <script> UpLoadFileCheck=function(){ this.AllowExt=".jpg,.gif"; //允许上传的文件类型 0为无限制 //每个扩展名后边要加一个"," 小写字母表示 this.AllowImgFileSize=0; //允许上传文件的大小 0为无限制 单位:KB this.AllowImgWidth=0; //允许上传的图片的宽度 0为无限制 单位:px(像素) this.AllowImgHeight=0; //允许上传的图片的高度 0为无限制 单位:px(像素) this.ImgObj=new Image(); this.ImgFileSize=0; this.ImgWidth=0; this.ImgHeight=0; this.FileExt=""; this.ErrMsg=""; this.IsImg=false;//全局变量 } UpLoadFileCheck.prototype.CheckExt=function(obj){ this.ErrMsg=""; this.ImgObj.src=obj.value; //this.HasChecked=false; if(obj.value==""){ this.ErrMsg="\n请选择一个文件"; } else{ this.FileExt=obj.value.substr(obj.value.lastIndexOf(".")).toLowerCase(); //判断文件类型是否允许上传 if(this.AllowExt!=0&&this.AllowExt.indexOf(this.FileExt)==-1){ this.ErrMsg="\n该文件类型不允许上传。请上传 "+this.AllowExt+" 类型的文件,当前文件类型为"+this.FileExt; } } if(this.ErrMsg!=""){ this.ShowMsg(this.ErrMsg,false); return false; } else return this.CheckProperty(obj); } UpLoadFileCheck.prototype.CheckProperty=function(obj){ if(this.ImgObj.readyState!="complete"){ sleep(1000);//一秒使用图能完全加载 } if(this.IsImg==true){ this.ImgWidth=this.ImgObj.width; //取得图片的宽度 this.ImgHeight=this.ImgObj.height; //取得图片的高度 if(this.AllowImgWidth!=0&&this.AllowImgWidth<this.ImgWidth) this.ErrMsg=this.ErrMsg+"\n图片宽度超过限制。请上传宽度小于"+this.AllowImgWidth+"px的文件,当前图片宽度为"+this.ImgWidth+"px"; if(this.AllowImgHeight!=0&&this.AllowImgHeight<this.ImgHeight) this.ErrMsg=this.ErrMsg+"\n图片高度超过限制。请上传高度小于"+this.AllowImgHeight+"px的文件,当前图片高度为"+this.ImgHeight+"px"; } this.ImgFileSize=Math.round(this.ImgObj.fileSize/1024*100)/100; //取得图片文件的大小 if(this.AllowImgFileSize!=0&&this.AllowImgFileSize<this.ImgFileSize) this.ErrMsg=this.ErrMsg+"\n文件大小超过限制。请上传小于"+this.AllowImgFileSize+"KB的文件,当前文件大小为"+this.ImgFileSize+"KB"; if(this.ErrMsg!=""){ this.ShowMsg(this.ErrMsg,false); return false; } else return true; } //显示提示信息 tf=false 显示错误信息 msg-信息内容 UpLoadFileCheck.prototype.ShowMsg=function(msg,tf){ /*msg=msg.replace("\n","<li>"); msg=msg.replace(/\n/gi,"<li>"); */ alert(msg); } function sleep(num){ var tempDate=new Date(); var tempStr=""; var theXmlHttp = new ActiveXObject( "Microsoft.XMLHTTP" ); while((new Date()-tempDate)<num ){ tempStr+="\n"+(new Date()-tempDate); try{ theXmlHttp .open( "get", "about:blank?JK="+Math.random(), false ); theXmlHttp .send(); } catch(e){;} } //containerDiv.innerText=tempStr; return; } function c(obj){ var d=new UpLoadFileCheck(); d.IsImg=true; d.AllowImgFileSize=100; d.CheckExt(obj) } </script> </head> <body> <input name="" type="file" onchange="c(this)"/> </body> </html>
一线大厂高级前端编写,前端初中阶面试题,帮助初学者应聘,需要联系微信:javadudu