本文实例讲述了js验证上传图片的方法。分享给大家供大家参考。具体实现方法如下:
<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\"
\"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">
<html xmlns=\"http://www.w3.org/1999/xhtml\">
<head>
<meta http-equiv=\"Content-Type\" content=\"text/html; charset=utf-8\" />
<title>js验证图片</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;
}
UpLoadFileCheck.prototype.ShowMsg=function(msg,tf)
//显示提示信息 tf=false 显示错误信息 msg-信息内容
{
/*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>
希望本文所述对大家的javascript程序设计有所帮助。
本文地址:https://www.stayed.cn/item/4270
转载请注明出处。
本站部分内容来源于网络,如侵犯到您的权益,请 联系我