js实现文件批量上传,支持ie firefox
该功能实现了多文件上传功能,点击添加是同时将文件显示在下面的列表。支持删除功能。
 using System.Data;
using System.Data;
 using System.Configuration;
using System.Configuration;
 using System.Collections;
using System.Collections;
 using System.Web;
using System.Web;
 using System.Web.Security;
using System.Web.Security;
 using System.Web.UI;
using System.Web.UI;
 using System.Web.UI.WebControls;
using System.Web.UI.WebControls;
 using System.Web.UI.WebControls.WebParts;
using System.Web.UI.WebControls.WebParts;
 using System.Web.UI.HtmlControls;
using System.Web.UI.HtmlControls;
 using System.IO;
using System.IO;
 using System.Text.RegularExpressions;
using System.Text.RegularExpressions;

 public partial class Default2 : System.Web.UI.Page
public partial class Default2 : System.Web.UI.Page
 {
{
 protected void Page_Load(object sender, EventArgs e)
    protected void Page_Load(object sender, EventArgs e)
 {
    {
 Regex badCharReplace = new Regex(@"^([<>""'%;()&])$");
        Regex badCharReplace = new Regex(@"^([<>""'%;()&])$");

 }
    }
 protected void Button2_Click(object sender, EventArgs e)
    protected void Button2_Click(object sender, EventArgs e)
 {
    {
 /////附件
        /////附件
 HttpFileCollection fileList = HttpContext.Current.Request.Files;
        HttpFileCollection fileList = HttpContext.Current.Request.Files;
 //保存附件
        //保存附件
 for (int i = 0; i < fileList.Count; i++)
        for (int i = 0; i < fileList.Count; i++)
 {   ///添加单个附件
        {   ///添加单个附件
 HttpPostedFile file = fileList[i];
            HttpPostedFile file = fileList[i];
 if (file.FileName.Length <= 0 || file.ContentLength <= 0)
            if (file.FileName.Length <= 0 || file.ContentLength <= 0)
 {
            {
 break;
                break;
 }
            }
 // 保存附件到硬盘中
            // 保存附件到硬盘中
 file.SaveAs(MapPath("Attachments/" + Path.GetFileName(file.FileName)));
            file.SaveAs(MapPath("Attachments/" + Path.GetFileName(file.FileName)));

 }
        }
 }
    }
 }
}

 using System.Data;
using System.Data; using System.Configuration;
using System.Configuration; using System.Collections;
using System.Collections; using System.Web;
using System.Web; using System.Web.Security;
using System.Web.Security; using System.Web.UI;
using System.Web.UI; using System.Web.UI.WebControls;
using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts;
using System.Web.UI.WebControls.WebParts; using System.Web.UI.HtmlControls;
using System.Web.UI.HtmlControls; using System.IO;
using System.IO; using System.Text.RegularExpressions;
using System.Text.RegularExpressions;
 public partial class Default2 : System.Web.UI.Page
public partial class Default2 : System.Web.UI.Page {
{ protected void Page_Load(object sender, EventArgs e)
    protected void Page_Load(object sender, EventArgs e) {
    { Regex badCharReplace = new Regex(@"^([<>""'%;()&])$");
        Regex badCharReplace = new Regex(@"^([<>""'%;()&])$");
 }
    } protected void Button2_Click(object sender, EventArgs e)
    protected void Button2_Click(object sender, EventArgs e) {
    { /////附件
        /////附件 HttpFileCollection fileList = HttpContext.Current.Request.Files;
        HttpFileCollection fileList = HttpContext.Current.Request.Files; //保存附件
        //保存附件 for (int i = 0; i < fileList.Count; i++)
        for (int i = 0; i < fileList.Count; i++) {   ///添加单个附件
        {   ///添加单个附件 HttpPostedFile file = fileList[i];
            HttpPostedFile file = fileList[i]; if (file.FileName.Length <= 0 || file.ContentLength <= 0)
            if (file.FileName.Length <= 0 || file.ContentLength <= 0) {
            { break;
                break; }
            } // 保存附件到硬盘中
            // 保存附件到硬盘中 file.SaveAs(MapPath("Attachments/" + Path.GetFileName(file.FileName)));
            file.SaveAs(MapPath("Attachments/" + Path.GetFileName(file.FileName)));
 }
        } }
    } }
}
前台代码
@ Page Language="C#" AutoEventWireup="true" CodeFile="Default2.aspx.cs" Inherits="Default2" %>

 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

 <html xmlns="http://www.w3.org/1999/xhtml" >
<html xmlns="http://www.w3.org/1999/xhtml" >
 <head runat="server">
<head runat="server">
 <title>Untitled Page</title>
    <title>Untitled Page</title>
 <script language="javascript" type="text/javascript">
    <script language="javascript" type="text/javascript">    
 function addFile()
  function addFile()
 {
  {
 //创建输入元素(通用代码)
    //创建输入元素(通用代码)
 //添加上传文件按钮
    //添加上传文件按钮
 var fileUpLoadbutton = document.createElement("input");
    var fileUpLoadbutton = document.createElement("input"); 
 fileUpLoadbutton.setAttribute("type","file");
    fileUpLoadbutton.setAttribute("type","file");
 fileUpLoadbutton.setAttribute("size","50");
    fileUpLoadbutton.setAttribute("size","50");
 fileUpLoadbutton.setAttribute("name","File");
    fileUpLoadbutton.setAttribute("name","File");
 fileUpLoadbutton.setAttribute("class","ButtonCss");
    fileUpLoadbutton.setAttribute("class","ButtonCss");
 //添加删除按钮
    //添加删除按钮
 var deleteImgbutton = document.createElement("img");
    var deleteImgbutton = document.createElement("img"); 
 deleteImgbutton.setAttribute("src","images/Btdelete.gif");
    deleteImgbutton.setAttribute("src","images/Btdelete.gif");
 deleteImgbutton.setAttribute("style","width: 38px; height: 20px");
    deleteImgbutton.setAttribute("style","width: 38px; height: 20px");
 //给
    //给
 deleteImgbutton.onclick=function(){deleteRow(1,this);};
    deleteImgbutton.onclick=function(){deleteRow(1,this);};

 
    
 var lastIndex= document.getElementById('FileList').childNodes.length-1;
    var lastIndex= document.getElementById('FileList').childNodes.length-1;
 
    
 
    
 if(lastIndex>-1)
     if(lastIndex>-1)
 {
     {
 
    
 
     
 var hideFile=document.getElementById('FileList').childNodes[lastIndex];
        var hideFile=document.getElementById('FileList').childNodes[lastIndex];
 
        
 if(hideFile.value=="")
         if(hideFile.value=="")
 {
         {
 return;
            return;
 }
         }
 
        
 hideFile.style.display="none";
        hideFile.style.display="none";
 var cell1 = document.createElement("td");
        var cell1 = document.createElement("td");
 var cell2 = document.createElement("td");
        var cell2 = document.createElement("td");  
 // var str = hideFile.value;
       // var str = hideFile.value;
 var myList =new Array();
        var myList =new Array();
 myList=  hideFile.value.split("""");
        myList=  hideFile.value.split("""");
 cell1.innerHTML = myList[myList.length-1];// hideFile.value;
        cell1.innerHTML = myList[myList.length-1];// hideFile.value;         
 cell2.appendChild(deleteImgbutton);
        cell2.appendChild(deleteImgbutton);
 var row = document.createElement("tr");
        var row = document.createElement("tr");
 row.appendChild(cell1);
        row.appendChild(cell1); 
 row.appendChild(cell2);
        row.appendChild(cell2);
 var tBody = document.createElement("tbody").appendChild(row);
        var tBody = document.createElement("tbody").appendChild(row);
 //识别当前浏览器
        //识别当前浏览器
 if(navigator.appName.indexOf("Explorer") > -1)
        if(navigator.appName.indexOf("Explorer") > -1)
 {
        {
 document.getElementById("FileTable").childNodes[0].appendChild(tBody);
            document.getElementById("FileTable").childNodes[0].appendChild(tBody); 
 }
        }
 else
        else
 {
        {
 document.getElementById("FileTable").appendChild(tBody);
            document.getElementById("FileTable").appendChild(tBody);
 }
        }   
 }
     }
 
     
 document.getElementById('FileList').appendChild(fileUpLoadbutton);
     document.getElementById('FileList').appendChild(fileUpLoadbutton);
 }
  }
 
  
 function deleteRow(targPos,btnObj)
   function deleteRow(targPos,btnObj)
 {
    {
 var tabObj=document.getElementById("FileTable");
       var tabObj=document.getElementById("FileTable");
 
        
 var fileListLength = document.getElementById('FileList').childNodes.length;
        var fileListLength = document.getElementById('FileList').childNodes.length;
 
        
 var tabRowsLength = tabObj.rows.length;
        var tabRowsLength = tabObj.rows.length;
 
         
 for(var i =0;i<tabRowsLength;i++)
        for(var i =0;i<tabRowsLength;i++)
 {
        {
 if(tabObj.getElementsByTagName('img')[i]==btnObj)
            if(tabObj.getElementsByTagName('img')[i]==btnObj)
 {
            {
 //删除当前选中行
                 //删除当前选中行
 tabObj.deleteRow(i+targPos);
                tabObj.deleteRow(i+targPos);
 //获得选中行对应的上传我文件对象
                //获得选中行对应的上传我文件对象
 var oldChild = document.getElementById('FileList').childNodes[i];
                var oldChild = document.getElementById('FileList').childNodes[i];
 //删除上传文件对象
                //删除上传文件对象
 document.getElementById('FileList').removeChild(oldChild);
                document.getElementById('FileList').removeChild(oldChild);
 
              
 }
            }          
 }
        }
 }
  }
 
  
 </script>
    </script>
 </head>
</head>
 <body>
<body>
 <form id="form1" runat="server">
    <form id="form1" runat="server">
 <div>
    <div>
 <table border="0" cellpadding="0" cellspacing="0" height="26" width="100%">
    <table border="0" cellpadding="0" cellspacing="0" height="26" width="100%">
 <tr>
            <tr>
 <td align="left" valign="middle">
                <td align="left" valign="middle">
 <asp:Button ID="Button2" runat="server" OnClick="Button2_Click" Text="提交" />
                    <asp:Button ID="Button2" runat="server" OnClick="Button2_Click" Text="提交" />
 </td>
                   </td>
 </tr>
            </tr>
 </table>
        </table>
 <table border="0" cellpadding="0" cellspacing="0" height="26" width="100%">
         <table border="0" cellpadding="0" cellspacing="0" height="26" width="100%">
 <tr>
            <tr>
 <td align="left" valign="middle">
                <td align="left" valign="middle">
 <DIV id="FileList"><input id="File1" runat="server" name="File" size="50" type="file" /></DIV>
                   <DIV id="FileList"><input id="File1" runat="server" name="File" size="50" type="file" /></DIV>
 </td>
                </td>
 <td>
                <td>
 <input id="Button1" onclick="addFile()" size="26" style="height: 26px" type="button" value="增加附件" />
                   <input id="Button1" onclick="addFile()" size="26" style="height: 26px" type="button" value="增加附件" />
 </td>
                </td>
 </tr>
            </tr>
 </table>
        </table>
 <table style="width:100%"  id="FileTable">
         <table style="width:100%"  id="FileTable">
 
         
 <tr>
            <tr>
 <td style="width:80%">FileName</td>
                <td style="width:80%">FileName</td>
 <td style="width:80%">button</td>
                <td style="width:80%">button</td>
 
                
 </tr>
            </tr>
 
           
 </table>
        </table>
 </div>
    </div>
 </form>
    </form>
 </body>
</body>
 </html>
</html>


 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 <html xmlns="http://www.w3.org/1999/xhtml" >
<html xmlns="http://www.w3.org/1999/xhtml" > <head runat="server">
<head runat="server"> <title>Untitled Page</title>
    <title>Untitled Page</title> <script language="javascript" type="text/javascript">
    <script language="javascript" type="text/javascript">     function addFile()
  function addFile() {
  { //创建输入元素(通用代码)
    //创建输入元素(通用代码) //添加上传文件按钮
    //添加上传文件按钮 var fileUpLoadbutton = document.createElement("input");
    var fileUpLoadbutton = document.createElement("input");  fileUpLoadbutton.setAttribute("type","file");
    fileUpLoadbutton.setAttribute("type","file"); fileUpLoadbutton.setAttribute("size","50");
    fileUpLoadbutton.setAttribute("size","50"); fileUpLoadbutton.setAttribute("name","File");
    fileUpLoadbutton.setAttribute("name","File"); fileUpLoadbutton.setAttribute("class","ButtonCss");
    fileUpLoadbutton.setAttribute("class","ButtonCss"); //添加删除按钮
    //添加删除按钮 var deleteImgbutton = document.createElement("img");
    var deleteImgbutton = document.createElement("img");  deleteImgbutton.setAttribute("src","images/Btdelete.gif");
    deleteImgbutton.setAttribute("src","images/Btdelete.gif"); deleteImgbutton.setAttribute("style","width: 38px; height: 20px");
    deleteImgbutton.setAttribute("style","width: 38px; height: 20px"); //给
    //给 deleteImgbutton.onclick=function(){deleteRow(1,this);};
    deleteImgbutton.onclick=function(){deleteRow(1,this);};
 
     var lastIndex= document.getElementById('FileList').childNodes.length-1;
    var lastIndex= document.getElementById('FileList').childNodes.length-1; 
     
     if(lastIndex>-1)
     if(lastIndex>-1) {
     { 
     
      var hideFile=document.getElementById('FileList').childNodes[lastIndex];
        var hideFile=document.getElementById('FileList').childNodes[lastIndex]; 
         if(hideFile.value=="")
         if(hideFile.value=="") {
         { return;
            return; }
         } 
         hideFile.style.display="none";
        hideFile.style.display="none"; var cell1 = document.createElement("td");
        var cell1 = document.createElement("td"); var cell2 = document.createElement("td");
        var cell2 = document.createElement("td");   // var str = hideFile.value;
       // var str = hideFile.value; var myList =new Array();
        var myList =new Array(); myList=  hideFile.value.split("""");
        myList=  hideFile.value.split(""""); cell1.innerHTML = myList[myList.length-1];// hideFile.value;
        cell1.innerHTML = myList[myList.length-1];// hideFile.value;          cell2.appendChild(deleteImgbutton);
        cell2.appendChild(deleteImgbutton); var row = document.createElement("tr");
        var row = document.createElement("tr"); row.appendChild(cell1);
        row.appendChild(cell1);  row.appendChild(cell2);
        row.appendChild(cell2); var tBody = document.createElement("tbody").appendChild(row);
        var tBody = document.createElement("tbody").appendChild(row); //识别当前浏览器
        //识别当前浏览器 if(navigator.appName.indexOf("Explorer") > -1)
        if(navigator.appName.indexOf("Explorer") > -1) {
        { document.getElementById("FileTable").childNodes[0].appendChild(tBody);
            document.getElementById("FileTable").childNodes[0].appendChild(tBody);  }
        } else
        else {
        { document.getElementById("FileTable").appendChild(tBody);
            document.getElementById("FileTable").appendChild(tBody); }
        }    }
     } 
      document.getElementById('FileList').appendChild(fileUpLoadbutton);
     document.getElementById('FileList').appendChild(fileUpLoadbutton); }
  } 
   function deleteRow(targPos,btnObj)
   function deleteRow(targPos,btnObj) {
    { var tabObj=document.getElementById("FileTable");
       var tabObj=document.getElementById("FileTable"); 
         var fileListLength = document.getElementById('FileList').childNodes.length;
        var fileListLength = document.getElementById('FileList').childNodes.length; 
         var tabRowsLength = tabObj.rows.length;
        var tabRowsLength = tabObj.rows.length; 
          for(var i =0;i<tabRowsLength;i++)
        for(var i =0;i<tabRowsLength;i++) {
        { if(tabObj.getElementsByTagName('img')[i]==btnObj)
            if(tabObj.getElementsByTagName('img')[i]==btnObj) {
            { //删除当前选中行
                 //删除当前选中行 tabObj.deleteRow(i+targPos);
                tabObj.deleteRow(i+targPos); //获得选中行对应的上传我文件对象
                //获得选中行对应的上传我文件对象 var oldChild = document.getElementById('FileList').childNodes[i];
                var oldChild = document.getElementById('FileList').childNodes[i]; //删除上传文件对象
                //删除上传文件对象 document.getElementById('FileList').removeChild(oldChild);
                document.getElementById('FileList').removeChild(oldChild); 
               }
            }           }
        } }
  } 
   </script>
    </script> </head>
</head> <body>
<body> <form id="form1" runat="server">
    <form id="form1" runat="server"> <div>
    <div> <table border="0" cellpadding="0" cellspacing="0" height="26" width="100%">
    <table border="0" cellpadding="0" cellspacing="0" height="26" width="100%"> <tr>
            <tr> <td align="left" valign="middle">
                <td align="left" valign="middle"> <asp:Button ID="Button2" runat="server" OnClick="Button2_Click" Text="提交" />
                    <asp:Button ID="Button2" runat="server" OnClick="Button2_Click" Text="提交" /> </td>
                   </td> </tr>
            </tr> </table>
        </table> <table border="0" cellpadding="0" cellspacing="0" height="26" width="100%">
         <table border="0" cellpadding="0" cellspacing="0" height="26" width="100%"> <tr>
            <tr> <td align="left" valign="middle">
                <td align="left" valign="middle"> <DIV id="FileList"><input id="File1" runat="server" name="File" size="50" type="file" /></DIV>
                   <DIV id="FileList"><input id="File1" runat="server" name="File" size="50" type="file" /></DIV> </td>
                </td> <td>
                <td> <input id="Button1" onclick="addFile()" size="26" style="height: 26px" type="button" value="增加附件" />
                   <input id="Button1" onclick="addFile()" size="26" style="height: 26px" type="button" value="增加附件" /> </td>
                </td> </tr>
            </tr> </table>
        </table> <table style="width:100%"  id="FileTable">
         <table style="width:100%"  id="FileTable"> 
          <tr>
            <tr> <td style="width:80%">FileName</td>
                <td style="width:80%">FileName</td> <td style="width:80%">button</td>
                <td style="width:80%">button</td> 
                 </tr>
            </tr> 
            </table>
        </table> </div>
    </div> </form>
    </form> </body>
</body> </html>
</html>
 
                    
                     
                    
                 
                    
                
 
     
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号