首頁  >  文章  >  web前端  >  JavaScript實作清空(重置)檔案類型INPUT元素值的方法

JavaScript實作清空(重置)檔案類型INPUT元素值的方法

高洛峰
高洛峰原創
2016-12-06 15:26:151338瀏覽

本文實例講述了JavaScript實作清空(重置)檔案類型INPUT元素值的方法。分享給大家供大家參考,具體如下:

因為安全限制,腳本是不能隨意設定其value值的,所以並不能像其它表單輸入域那樣用屬性來設定使其重置。

重置一個檔案域的值,歸納起來主要有 3 種方法。

本文分析這三種方法的瀏覽器相容性以及優缺點,並給出一個比較完美的綜合方案的程式碼和Demo。

重置檔案域的三種方法:

1. 設定value屬性為空。

對於IE11以上和其它較新的非IE的現代瀏覽器Chrome/Firefox/Opera...有效。

2. 複製或建立一個新的檔案輸入元素進行替換。

利用createElement或cloneNode複製或建立一個新元素進行替換,適用於所有瀏覽器。缺點也很明顯,就是替換後,將會遺失原先綁定的事件監聽器,並且遺失一些自訂的expando屬性。沒有這個問題的情況下可以使用,不通用,我不建議使用這個方法。

3. 呼叫表單form元素的reset()方法。

form元素的reset()方法會重置表單內的所有輸入元素,這並不是我們期望的,所以可以變通一下,創建一個新的form對象,將文件input元素放進去之後再reset,再把文件input元素取出放回原處,這樣就不會出現方法2的弊端了。

利用方法1和方法3結合,可以做到相容所有瀏覽器。

JavaScript函數程式碼如下:

function clearInputFile(f){
  if(f.value){
    try{
      f.value = ''; //for IE11, latest Chrome/Firefox/Opera...
    }catch(err){
    }
    if(f.value){ //for IE5 ~ IE10
      var form = document.createElement('form'), ref = f.nextSibling, p = f.parentNode;
      form.appendChild(f);
      form.reset();
      p.insertBefore(f,ref);
    }
  }
}

   


陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn