欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

真正好用的js驗(yàn)證上傳文件大小的簡(jiǎn)單方法

 更新時(shí)間:2016年10月27日 09:22:01   投稿:jingxian  
下面小編就為大家?guī)?lái)一篇真正好用的js驗(yàn)證上傳文件大小的簡(jiǎn)單方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

最近使用到一個(gè)文件上傳功能,發(fā)現(xiàn)惡意上傳一個(gè)2G文件時(shí),后臺(tái)處理響應(yīng)較慢,遂想到能否使用js來(lái)進(jìn)行客戶端的驗(yàn)證。但查閱網(wǎng)上多處資料,均使用 ActiveXObject("Scripting.FileSystemObject"); 的方法,該方法需要將Internet選項(xiàng)中安全級(jí)別提高,啟用一個(gè)系統(tǒng)本身不推薦的選項(xiàng),會(huì)出現(xiàn)如下非常不友好的提示:

所以這邊并沒(méi)有用到,而是尋求其他方法。

這邊新的思路是img標(biāo)簽中的dynsrc屬性。

在FireFox、Chrome瀏覽器中可以根據(jù)document.getElementById(“id_file”).files[0].size 獲取上傳文件的大小(字節(jié)數(shù)),而IE瀏覽器中不支持該屬性,只能借助<img>標(biāo)簽的dynsrc屬性,來(lái)間接實(shí)現(xiàn)獲取文件的大?。?span style="color: rgb(0,0,255)">但需要同意ActiveX控件的運(yùn)行,但是不會(huì)引起上面的不友好、不安全的提示)。

具體方法如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
  <head> 
  <meta name="DEscription" contect="my code demo" /> 
  <meta name="Author" contect="Michael@www.micmiu.com" /> 
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
  <title>js check file size @ www.micmiu.com</title> 
  </head> 
  <body> 
    <img id="tempimg" dynsrc="" src="" style="display:none" /> 
    <input type="file" name="file" id="fileuploade" size="40" /> 
    <input type="button" name ="check" value="checkfilesize" onclick="checkfile()"/> 
 
  </body> 
  <script type="text/javascript"> 
    var maxsize = 2*1024*1024;//2M 
    var errMsg = "上傳的附件文件不能超過(guò)2M!?。?; 
    var tipMsg = "您的瀏覽器暫不支持計(jì)算上傳文件的大小,確保上傳文件不要超過(guò)2M,建議使用IE、FireFox、Chrome瀏覽器。"; 
    var browserCfg = {}; 
    var ua = window.navigator.userAgent; 
    if (ua.indexOf("MSIE")>=1){ 
      browserCfg.ie = true; 
    }else if(ua.indexOf("Firefox")>=1){ 
      browserCfg.firefox = true; 
    }else if(ua.indexOf("Chrome")>=1){ 
      browserCfg.chrome = true; 
    } 
    function checkfile(){ 
      try{ 
        var obj_file = document.getElementById("fileuploade"); 
        if(obj_file.value==""){ 
          alert("請(qǐng)先選擇上傳文件"); 
          return; 
        } 
        var filesize = 0; 
        if(browserCfg.firefox || browserCfg.chrome ){ 
          filesize = obj_file.files[0].size; 
        }else if(browserCfg.ie){ 
          var obj_img = document.getElementById('tempimg'); 
          obj_img.dynsrc=obj_file.value; 
          filesize = obj_img.fileSize; 
        }else{ 
          alert(tipMsg); 
        return; 
        } 
        if(filesize==-1){ 
          alert(tipMsg); 
          return; 
        }else if(filesize>maxsize){ 
          alert(errMsg); 
          return; 
        }else{ 
          alert("文件大小符合要求"); 
          return; 
        } 
      }catch(e){ 
        alert(e); 
      } 
    } 
  </script> 
</html> 

以上就是小編為大家?guī)?lái)的真正好用的js驗(yàn)證上傳文件大小的簡(jiǎn)單方法全部?jī)?nèi)容了,希望大家多多支持腳本之家~

相關(guān)文章

  • Javascript筆記一 js以及json基礎(chǔ)使用說(shuō)明

    Javascript筆記一 js以及json基礎(chǔ)使用說(shuō)明

    JavaScript中的數(shù)據(jù)很簡(jiǎn)潔的。簡(jiǎn)單數(shù)據(jù)只有 undefined, null, boolean, number和string這五種,而復(fù)雜數(shù)據(jù)只有一種,即object。
    2010-05-05
  • 原生JS實(shí)現(xiàn)分頁(yè)點(diǎn)擊控件

    原生JS實(shí)現(xiàn)分頁(yè)點(diǎn)擊控件

    這篇文章主要為大家詳細(xì)介紹了原生JS實(shí)現(xiàn)分頁(yè)點(diǎn)擊控件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • 全面解析JavaScript中offsetLeft、offsetTop的用法

    全面解析JavaScript中offsetLeft、offsetTop的用法

    本文主要介紹了全面解析JavaScript中offsetLeft、offsetTop的用法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • Javascript實(shí)現(xiàn)動(dòng)態(tài)菜單添加的實(shí)例代碼

    Javascript實(shí)現(xiàn)動(dòng)態(tài)菜單添加的實(shí)例代碼

    在注冊(cè)信息的時(shí)候,常常需要通過(guò)下拉菜單讓用戶選擇,而且希望用戶在第一個(gè)下拉框做的選擇,影響第二個(gè)下拉框的內(nèi)容。有時(shí)候,如果第一個(gè)下拉框不作出選擇,第二個(gè)下拉框根本不會(huì)頁(yè)面上顯示,為了給用戶呈現(xiàn)一個(gè)更清晰的頁(yè)面。
    2013-07-07
  • 淺談javascript中的prototype和__proto__的理解

    淺談javascript中的prototype和__proto__的理解

    這篇文章主要介紹了淺談javascript中的prototype和__proto__的理解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • JavaScript實(shí)現(xiàn)維吉尼亞(Vigenere)密碼算法實(shí)例

    JavaScript實(shí)現(xiàn)維吉尼亞(Vigenere)密碼算法實(shí)例

    Vigenere密碼就是一種傳統(tǒng)加密技術(shù),它是多表代換密碼,能夠有效改進(jìn)單表代換密碼的詞頻分布特征問(wèn)題,本文用JavaScript實(shí)現(xiàn)維吉尼亞(Vigenere)密碼算法
    2013-11-11
  • 淺析js實(shí)現(xiàn)網(wǎng)頁(yè)截圖的兩種方式

    淺析js實(shí)現(xiàn)網(wǎng)頁(yè)截圖的兩種方式

    這篇文章主要介紹了淺析js實(shí)現(xiàn)網(wǎng)頁(yè)截圖的兩種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • JS實(shí)現(xiàn)音樂(lè)導(dǎo)航特效

    JS實(shí)現(xiàn)音樂(lè)導(dǎo)航特效

    這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)音樂(lè)導(dǎo)航特效,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-01-01
  • javascript去掉前后空格的實(shí)例

    javascript去掉前后空格的實(shí)例

    在js中去除空格并不是可以直接使用trim來(lái)刪除,它在js中并不像我們想的那么好用,特別像我要?jiǎng)h除前后空格這個(gè)trim函數(shù)更不可靠了
    2013-11-11
  • JavaScript基于對(duì)象方法實(shí)現(xiàn)數(shù)組去重及排序操作示例

    JavaScript基于對(duì)象方法實(shí)現(xiàn)數(shù)組去重及排序操作示例

    這篇文章主要介紹了JavaScript基于對(duì)象方法實(shí)現(xiàn)數(shù)組去重及排序操作,涉及javascript基于對(duì)象方法的數(shù)組遍歷、比較、去重、排序等相關(guān)操作技巧,需要的朋友可以參考下
    2018-07-07

最新評(píng)論