javascript - 当前上下文值未从 Usercontrol 呈现到 .aspx 页面

标签 javascript asp.net ajax

我有 default.aspx 页面和一个用户控件。 用户控件具有以下用于多个文件上传的代码。 现在的问题是,当我添加一个要上传的文件时,当前上下文文件没有给我任何值,我猜它仍然为零,因为它是从用户控件呈现的。

我该怎么办?

我的用户控件 UPLOAD.ASCX

<%@ Control Language="C#" AutoEventWireup="true" CodeFile="FileUpload.ascx.cs" Inherits="FileUpload" %>
<script type="text/javascript" src="_scripts/jquery-1.4.1.min.js"></script>    
<script type="text/javascript">
    var i = 1;
    $(document).ready(function () {
        $("#addfile").click(function () {
            $("#dvfiles").append("<input name=" + i + "fu type=file /><a href=#>remove</a><br>");
            i++;
        });

        $("#dvfiles a").live('click', function () {
            $(this).prev("input[type=file]").remove();
            $(this).remove();
        });
    });

    $(document).submit(function () {
        var flag = true;
        $("#dvfiles input[type=file]").each(function () {
            if ($(this).val() == "") {
                $(this).css("background", "Red");
                flag = false;
            }
        });
        return flag;
    });        
</script>

<div id="Fileuploader">
<a href="#" id="addfile">Attach a file..</a><br />
<asp:Label ID="lblMessage" runat="server"></asp:Label><br />
<asp:Button ID="btnUpload" runat="server" Text="Upload"
    onclick="btnUpload_Click" />
</div>

UPLOAD.ASCX.CS

protected void btnUpload_Click(object sender, EventArgs e)
{
    try
    {
        HttpFileCollection filecolln = Request.Files; 
        //here i don't get values of current files.
      // this is zero. because of this following if condition failed 
       //please help here
        if (filecolln.Count > 0)
        {
            for (int i = 0; i < filecolln.Count; i++)
            {
                HttpPostedFile file = filecolln[i];
                if (file.ContentLength > 0)
                {
                    file.SaveAs(ConfigurationManager.AppSettings["FilePath"] + System.IO.Path.GetFileName(file.FileName));
                }
            }
            lblMessage.Text = "Uploaded Successfully!";
        }
        else
        {
            lblMessage.Text = "No files selected!";
        }

    }
    catch (Exception ex)
    {
        lblMessage.Text = ex.Message;
    }
}

Default.aspx代码

    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs"    
    Inherits="_Default" %>
    <%@ Register TagPrefix="ucFileuploader" tagName="Fileuploader" src="FileUpload.ascx"    %> 

   <!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">
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <ucFileuploader:Fileuploader ID="Fileuploder" runat="server" />
    </div>
    </form>
</body>
</html>

最佳答案

问题是您使用的是 javascript 和 id 名称。

因此,当您在 .aspx 中使用 id addfile 进行控制时,它会按原样呈现, 但是当你在用户控件中使用 id Fileuploader 控制 id addfile 时, 比呈现的 id 是 Fileuploader_addfile, 所以用正确的 id 在 java 脚本中更改 id 名称。

要检查呈现的 id 的名称,请在浏览器中打开页面,打开页面的源代码并找到您的元素并将 id 复制到 java 脚本中。 使用呈现的 ID 名称更改 Java 脚本中的所有 ID。

关于javascript - 当前上下文值未从 Usercontrol 呈现到 .aspx 页面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8325725/

相关文章:

asp.net - 我无法使用 sql 查询的输出填充列表框

javascript - 如何根据 PHP 端的 bool 变量通过 AJAX 更新和加载不同的 div block ?

javascript - 使用另一个数组对象的值来增加数组对象的值

javascript - JS onclick 触发错误的对象

Javascript - Highchart - 数据点和标志的工具提示位置

c# - 无法发布 .NET Core 应用程序(运行时不受支持)

jquery - 如何将我的 div 滑到另一个 div 上

javascript - 使用 Ajax 将值从 jquery 传递到 php

javascript - Select2 JS 不显示来自 AJAX 的数据

javascript - 使用 HTML5 History API 处理哈希