DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> js實現上傳文件添加和刪除文件選擇框
js實現上傳文件添加和刪除文件選擇框
編輯:關於JavaScript     

本文這裡給大家說個用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
//先增加兩個input

function 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>

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

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

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved