JavaScript用于多上传的问题

时间:2012-09-04 16:55:46

标签: c# javascript html multi-upload

我正在尝试进行多文件上传。在此blog的帮助下,但收到错误。

代码:

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="default.aspx.cs" Inherits="Upload_Multiple_Files._default" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>

    <script language="javascript" type="text/javascript">
        var selectedFiles = '';

        function ReceiveServerData(response) {
            alert(response);
        }

        function uploadFile() {
            var fileList = document.getElementById("fileDivBox").getElementsByTagName("INPUT");

            for (i = 0; i < fileList.length; i++) {
                selectedFiles += fileList[i].value + "|";
            }

            CallServer(selectedFiles, '');
        }

        function attachFile() {
            var fu = document.createElement("INPUT");

            fu.type = "file";

            var br = document.createElement("<BR>");

            document.getElementById("fileDivBox").appendChild(fu);
            document.getElementById("fileDivBox").appendChild(br);
        }
    </script>
</head>
<body>
    <form id="form1" runat="server">
        <div>
            <a href="#" onclick="attachFile()">Attach a file</a> 
        </div>
    </form>
</body>
</html>

代码隐藏:

namespace Upload_Multiple_Files
{
public partial class _default : System.Web.UI.Page
{
    public void RaiseCallbackEvent(string eventArgument)
    {
        string[] files = (eventArgument.TrimEnd('|')).Split('|');

        WebClient client = new WebClient();

        foreach (string file in files)
        {
            client.UploadFile("http://localhost:3850/FileServer.aspx", "POST", file);
        } 
    }

    protected void Page_Load(object sender, EventArgs e)
    {
        string path = @"C:\UploadedFiles\"; // server folder

        string[] keys = Request.Files.AllKeys;

        foreach (String key in keys)
        {
            HttpPostedFile file = Request.Files[key];

            file.SaveAs(path + file.FileName);
        }
    }
}
}

该行中出现错误:br = document.createElement("<BR>"); 它说“未处理的例外”。我是javascript的新手,因此没有任何线索是错误的。

1 个答案:

答案 0 :(得分:1)

document.CreateElement函数将添加&lt; &GT;标签的一部分给你。您的代码尝试执行的操作是创建<<br>>的元素,该元素无效。仅使用标签名称BR:

调用该方法
br = document.CreateElement("BR");

这将为您创建一个<br>标记。