js驗(yàn)證上傳圖片的方法
更新時(shí)間:2015年05月12日 15:33:26 作者:vivi
這篇文章主要介紹了js驗(yàn)證上傳圖片的方法,可對(duì)上傳圖片的類型、大小等進(jìn)行限制,非常簡單實(shí)用,需要的朋友可以參考下
本文實(shí)例講述了js驗(yàn)證上傳圖片的方法。分享給大家供大家參考。具體實(shí)現(xiàn)方法如下:
<!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驗(yàn)證圖片</title>
<script>
UpLoadFileCheck=function()
{
this.AllowExt=".jpg,.gif";
//允許上傳的文件類型 0為無限制
//每個(gè)擴(kuò)展名后邊要加一個(gè)"," 小寫字母表示
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請(qǐng)選擇一個(gè)文件";
}
else
{
this.FileExt=obj.value.substr(obj.value.lastIndexOf(".")).toLowerCase();
if(this.AllowExt!=0&&this.AllowExt.indexOf(this.FileExt)==-1)
//判斷文件類型是否允許上傳
{
this.ErrMsg="\n該文件類型不允許上傳。請(qǐng)上傳 "+this.AllowExt+" 類型的文件,當(dāng)前文件類型為"+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圖片寬度超過限制。請(qǐng)上傳寬度小于"+this.AllowImgWidth+"px的文件,當(dāng)前圖片寬度為"+this.ImgWidth+"px";
if(this.AllowImgHeight!=0&&this.AllowImgHeight<this.ImgHeight)
this.ErrMsg=this.ErrMsg+"\n圖片高度超過限制。請(qǐng)上傳高度小于"+this.AllowImgHeight+"px的文件,當(dāng)前圖片高度為"+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文件大小超過限制。請(qǐng)上傳小于"+this.AllowImgFileSize+"KB的文件,當(dāng)前文件大小為"+this.ImgFileSize+"KB";
if(this.ErrMsg!="")
{
this.ShowMsg(this.ErrMsg,false);
return false;
}
else
return true;
}
UpLoadFileCheck.prototype.ShowMsg=function(msg,tf)
//顯示提示信息 tf=false 顯示錯(cuò)誤信息 msg-信息內(nèi)容
{
/*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>
希望本文所述對(duì)大家的javascript程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:
- 多個(gè)上傳文件用js驗(yàn)證文件的格式和大小的方法(推薦)
- 真正好用的js驗(yàn)證上傳文件大小的簡單方法
- javascript驗(yàn)證上傳文件的類型限制必須為某些格式
- Node.js開發(fā)教程之基于OnceIO框架實(shí)現(xiàn)文件上傳和驗(yàn)證功能
- Javascript驗(yàn)證上傳圖片大小[前臺(tái)處理]
- 上傳的js驗(yàn)證(圖片/文件的擴(kuò)展名)
- js 圖片上傳前大小長寬驗(yàn)證代碼
- javascript 客戶端驗(yàn)證上傳圖片的大?。嫒軮E和火狐)
- Javascript 驗(yàn)證上傳圖片大小[客戶端]
- JS簡單驗(yàn)證上傳文件類型的方法
相關(guān)文章
用javascript模仿ie的自動(dòng)完成類似自動(dòng)完成功的表單
最近在寫一個(gè)javascript框架,看見網(wǎng)上有不少自動(dòng)完成功能的表單,于是用javascript寫了一個(gè),需要的朋友可以參考下2012-12-12
Javascript實(shí)現(xiàn)基本運(yùn)算器
這篇文章主要為大家詳細(xì)介紹了Javascript實(shí)現(xiàn)基本運(yùn)算器的相關(guān)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07
js判斷當(dāng)頁面無法回退時(shí)關(guān)閉網(wǎng)頁否則就history.go(-1)
當(dāng)頁面沒有前驅(qū)歷史記錄時(shí),點(diǎn)擊返回按鈕時(shí)直接關(guān)閉頁面,否則就退回到前一頁2014-08-08
js使瀏覽器窗口最大化實(shí)現(xiàn)代碼(適用于IE)
點(diǎn)擊最大化按鈕后,瀏覽器的內(nèi)容填充滿顯示器,瀏覽器窗口的邊框被擠出顯示器。而該js的最大化效果是瀏覽器的邊框在顯示器內(nèi)顯示,具體實(shí)現(xiàn)如下,感興趣的朋友可以參考下2013-08-08
javascript實(shí)現(xiàn)簡約的頁面右下角點(diǎn)擊彈出窗口示例【測(cè)試可用】
這篇文章主要介紹了javascript實(shí)現(xiàn)的頁面右下角點(diǎn)擊彈出窗口功能,結(jié)合實(shí)例形式詳細(xì)分析了javascript頁面右下角點(diǎn)擊彈出窗口功能的相關(guān)步驟、原理與注意事項(xiàng),需要的朋友可以參考下2023-07-07

