国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

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

2024-05-06 16:32:55
字體:
來源:轉載
供稿:網友

本文實例講述了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/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宜阳县| 大英县| 云和县| 华宁县| 南宫市| 乳山市| 桦川县| 大姚县| 抚顺县| 庆云县| 孝感市| 应城市| 江西省| 武平县| 南昌市| 赞皇县| 泸西县| 盱眙县| 安泽县| 泸水县| 临夏市| 驻马店市| 松溪县| 石棉县| 陈巴尔虎旗| 博白县| 金坛市| 腾冲县| 南和县| 张家港市| 潮州市| 油尖旺区| 屏边| 北辰区| 西安市| 霍林郭勒市| 湖州市| 宜章县| 九江县| 余庆县| 武川县|