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

JavaScript實現(xiàn)清空(重置)文件類型INPUT元素值的方法

 更新時間:2016年11月17日 11:43:06   作者:cuixiping  
這篇文章主要介紹了JavaScript實現(xiàn)清空(重置)文件類型INPUT元素值的方法,結(jié)合實例形式分析了javascript清空input文本框的常用方法與實現(xiàn)技巧,需要的朋友可以參考下

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

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

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

本文分析這三種方法的瀏覽器兼容性以及優(yōu)缺點,并給出一個比較完美的綜合方案的代碼和Demo。

重置文件域的三種方法:

1. 設(shè)置value屬性為空。

對于IE11以上和其它較新的非IE的現(xiàn)代瀏覽器Chrome/Firefox/Opera...有效。

2. 克隆或創(chuàng)建一個新的文件輸入元素進行替換。

利用createElement或者cloneNode克隆或創(chuàng)建一個新元素進行替換,適用于所有瀏覽器。缺點也很明顯,就是替換后,將丟失原先綁定的事件監(jiān)聽器,并丟失一些自定義的expando屬性。沒有這個問題的情況下可以使用,不通用,我不建議使用這個方法。

3. 調(diào)用表單form元素的reset()方法。

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

利用方法1和方法3結(jié)合,可以做到兼容所有瀏覽器。

JavaScript函數(shù)代碼如下:

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);
    }
  }
}

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript查找算法技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《JavaScript中json操作技巧總結(jié)》、《JavaScript切換特效與技巧總結(jié)》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調(diào)試技巧總結(jié)》及《JavaScript數(shù)學運算用法總結(jié)

希望本文所述對大家JavaScript程序設(shè)計有所幫助。

相關(guān)文章

最新評論