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

首頁 > 編程 > JavaScript > 正文

js實現上傳文件添加和刪除文件選擇框

2019-11-20 08:41:08
字體:
來源:轉載
供稿:網友

本文這里給大家說個用javascript實現的很實用的功能,是在上傳附件的時候,可以動態地添加和刪除文件選擇框,然后一次性上傳。

從理論上看,實現起來比較容易,但實際工作的時候還是遇到兩個難點,這些難點歸結起來都是一個原因造成的,那就是瀏覽器的兼容性。在腳本中要用到兩個函數:insertAdjacentHTML和removeChild,而恰好這兩個函數在Firefox下都不能正常使用。幾乎花費了一天的時候,在網上搜索著解決的方法,還好被找到了,也讓我大松一口氣。

具體兩個函數是這樣的:

<script type="text/javascript">  //刪除文件選擇框  function removeFile(id) {    var new_tr = id.parentNode;    try {      //new_tr.removeNode(true);      // just ie , not w3c;      // other idea      var tmp = new_tr.parentNode;      // 為了在ie和firefox下都能正常使用,就要用另一個方法代替,最取上一層的父結點,然后remove.      tmp.removeChild(new_tr);     } catch(e) {}  }    //添加文件選擇框  function addFile(id)  {   var str = '<div><input type="file" runat="server" name="file" onKeyDown="this.blur();" oncontextmenu="return false" /><input type="button" value="刪除" style="height:22px;" onclick="removeFile(this)" /></div>'   insertHtml("beforeend",document.getElementById(id),str);   }</script>

頁面上這樣引用:

<div>    <input type="button" value="添加附件(Add)" onclick="addFile('myfile')">    </div>  <div id="myfile"></div>

在addFile函數中引用了另一個函數:insertHtml,這個函數主要是針對insertAdjacentHTML在firefox下無效的情況重寫的,具體可以通過搜索insertAdjacentHTML找到。

PS:清除file框的內容

<input  type=file  name=ttt>     <input  type=button  onclick="ttt.select();document.execCommand('Delete');"   value=清除file框的內容>

第二個案例

文件上傳,刪除效果圖:

剛開始:

點擊按鈕“選擇更多后”,可以添加很多選擇文件:

點擊按鈕“刪除”后:

實現代碼:

<!DOCTYPE html><html><head><meta charset="utf-8"><title>選擇文件</title><style type="text/css">*{margin:0px;padding:0px;}div{margin:10px;}</style><script>//當點擊添加更多時,增加一個DIV//先增加兩個inputfunction addFile(){var fragment=document.createDocumentFragment();var divNode=document.getElementById("container");var newDiv=document.createElement("div");newDiv.setAttribute("id","file");fragment.appendChild(newDiv);var newInput=document.createElement("input");newInput.setAttribute("type","file");newInput.setAttribute("name","選擇文件");newDiv.appendChild(newInput);var newInput=document.createElement("input");newInput.setAttribute("type","button");newInput.setAttribute("value","刪除");newInput.setAttribute("onclick","delFile()");newInput.setAttribute("id","1");newDiv.appendChild(newInput);divNode.appendChild(fragment);}function delFile(){var divNode=document.getElementById("container");divNode.removeChild(divNode.firstElementChild);}</script></head><body><input type="button" value="選擇更多" onclick="addFile()"/><div id="container"><div id="file"><input type="file" name="選擇文件"/><input type="button" value="刪除" onclick="delFile()" /></div></div></body></html>

代碼瑕疵:!!!!在刪除函數中,我選擇的是刪除第一個元素節點,而不是真正意義上的刪除當前按鈕,不知道怎么改善,求改正。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 大庆市| 南康市| 永顺县| 景宁| 正宁县| 凌云县| 永靖县| 准格尔旗| 宝山区| 衡南县| 崇阳县| 措美县| 顺义区| 邢台县| 凤冈县| 屏南县| 香河县| 沭阳县| 革吉县| 瓦房店市| 府谷县| 漠河县| 柯坪县| 江城| 香格里拉县| 承德市| 庆城县| 商南县| 黔东| 新巴尔虎右旗| 岫岩| 正安县| 团风县| 横峰县| 布拖县| 盐山县| 紫阳县| 黎川县| 晋中市| 家居| 章丘市|