IE+JS: 上傳之前檢測圖片文件大小及類型

IE+JS: 上傳之前檢測圖片文件大小October 2, 2005 at 1:34 am · Filed under Scripts

文件上傳之前的檢測,通常是通過文件名來判斷文件類型是否合法,但是要想檢測文件的大小很難辦到,除非在本地或者使用控件。不過在IE下img有幾個附加的屬性,如:fileCreatedDate、fileModifiedDate、fileSize、fileUpdatedDate、filters,我們可以通過這些屬性來獲取圖片文件的部分信息,如文件大小,我們用file表單同img標籤結合,就能夠在上傳之前判斷圖片文件的大小是否合法了。

還有一個小小的發現就是,IE下動畫的onload事件是在每次循環開始都觸發,這樣我們可以通過他來達到和js裏setInterval()函數一樣的效果,如:


這兩個例子的源代碼如下:
第一個:

限制:<input type="text" size="4" value="10" name="fileSizeLimit" id="fileSizeLimit"/> K
<input type="file" name="file1" id="file1" size="40" οnchange="changeSrc(this)"/>
<img src="about:blank" id="fileChecker" alt="test"  height="18"/>
   
<script type="text/javascript">
var oFileChecker = document.getElementById("fileChecker");
   
function changeSrc(filePicker)
{
    oFileChecker.src = filePicker.value;
}
   
oFileChecker.onreadystatechange = function ()
{
    if (oFileChecker.readyState == "complete")
    {
        checkSize();
    }
}
   
function checkSize()
{
    var limit  = document.getElementById("fileSizeLimit").value * 1024;
   
    if (oFileChecker.fileSize > limit)
    {
        alert("too large");
    }
    else
    {
        alert("ok");
    }
}
</script> 

第二個:

<img src="monkey.gif" id="monkey" alt="monkey" /> loops: <span id="loopsNum"></span>
   
<script type="text/javascript">
var loops = 0;
document.getElementById("monkey").onload = function ()
{
    document.getElementById("loopsNum").innerText= loops;
    loops ++;
}
</script> 

每三個:

<script>
function checkSize(imgObj)
{
alert(imgObj.fileSize);
}

</script>
<BODY>
<form id="aform">
<img id=im οnlοad="checkSize(this)" src="http://www.google.com/logos/winter_holiday05_5res.gif">
</form>
</BODY>

限制文件類型

function CheckFile(){
  with(document.aform){
  var filepath1 =SourceFile1.value;
  var fileextend1 = filepath1.substring(filepath1.lastIndexOf('.')+1,filepath1.length);
  if(fileextend1==""){
    alert("對不起,你必須選擇一個文件!");
    return false;
  }
  fileextend1 = fileextend1.toLowerCase();
  if(fileextend1 != "xls" && fileextend1 !="txt"){
    alert("對不起,您選擇的文件格式不對,請選擇文本文件(txt)或Excel文件。");
    return false;
  }
  if(fileextend1 == "xls"){
    if(!confirm("上傳EXCEL文件速度將會很慢,我們推薦您使用文本格式。你確定要使用這個文件嗎?")){
      return false;
      }
    }

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章