本文實例講述了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); } } }
更多關於JavaScript相關內容感興趣的讀者可查看本站專題:《JavaScript查找算法技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》、《JavaScript中json操作技巧總結》、《JavaScript切換特效與技巧總結》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調試技巧總結》及《JavaScript數學運算用法總結》
希望本文所述對大家JavaScript程序設計有所幫助。