用户控制中的事件

时间:2010-10-21 07:57:51

标签: c# asp.net user-controls

我在网络用户控件中遇到按钮事件的问题

首先我有一个像这样的aspx:

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

<!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>
    <script src="js/jquery-1.4.2.min.js" type="text/javascript"></script>
</head>
<body>
    <form id="form1" runat="server">
    <asp:ScriptManager ID="ScriptManager1" runat="server">
    </asp:ScriptManager>
    <div id="divContent" runat="server">
    </div>
    </form>    
</body>
</html>

如你所见,我有一个ScriptManager来处理ASP.NET AJAX,一个带有ID divContent的div来加载控件,然后在代码后面:

protected void Page_Load(object sender, EventArgs e)
{
    divContent.Controls.Add(LoadControl("~/thitai/addtest.ascx"));
}

如你所见,我将addtest.ascx添加到divContent,这是addtest.ascx的代码

<%@ Control Language="C#" AutoEventWireup="true" CodeBehind="addtest.ascx.cs" Inherits="thitai.addtest" %>
<asp:UpdatePanel ID="updatePanel" runat="server" ClientIDMode="Static">
    <ContentTemplate>
        <input type="button" value="Load text" onclick="updPanel('text');return false;" />
        <input type="button" value="Load image" onclick="updPanel('image');return false;" />
        <asp:HiddenField ID="hftype" runat="server" ClientIDMode="Static" />
        <div>
            <asp:PlaceHolder ID="plhControl" runat="server"></asp:PlaceHolder>
        </div>
        <asp:Label ID="Label1" runat="server" Text="Label"></asp:Label>
    </ContentTemplate>
</asp:UpdatePanel>
<script type="text/javascript">
    function updPanel(type) {
        $("#hftype").val(type);
        __doPostBack("updatePanel", "");
    }
</script>

每次我点击加载文字按钮,我改变hfType(隐藏字段)的值,然后使用UpdatePanel回发到服务器,然后这是代码隐藏

protected override void OnPreRender(EventArgs e)
{
     string type = hftype.Value;
     switch (type)
     {
                case "text":
                    plhControl.Controls.Add(LoadControl("~/thitai/test/text.ascx"));
                    break;
                case "image":
                    plhControl.Controls.Add(LoadControl("~/thitai/test/image.ascx"));
                    break;
                default:
                    plhControl.Controls.Add(LoadControl("~/thitai/test/text.ascx"));
                    break;
     }
     base.OnPreRender(e);
}

这是text.ascx的代码

<%@ Control Language="C#" AutoEventWireup="true" CodeBehind="text.ascx.cs" Inherits="thitai.test.text" %>
<%@ Register Assembly="Support" Namespace="Support.CustomEditor" TagPrefix="Editor" %>
<Editor:CustomEditor ID="edNoidung" runat="server" NoScript="True" Content=""
    Height="500" ActiveMode="Design" NoUnicode="True" InitialCleanUp="False" />
<div>
    <asp:Button ID="Button1" runat="server" Text="Show HTML" 
        onclick="Button1_Click" />
</div>
<div id="showHtml" runat="server"></div>

后面是text.ascx

的代码
protected void Button1_Click(object sender, EventArgs e)
{
    showHtml.InnerHtml = edNoidung.Content;
}

问题是:当我点击按钮1时,页面使用AJAX进行回发,但事件Button1_Click不会发生火灾!

对此有何想法?

1 个答案:

答案 0 :(得分:2)

控制事件总是在Page / Control PreRender之前发生。但是,在Page Prerender发生之前Button1不存在(因为您当时正在加载控件)。 要解决此问题,您可以在页面加载中移动控件(text.ascx)而不是预渲染。

编辑:或者,您可以在text.ascx page_load中嗅探请求数据,以检查是否已单击按钮。例如,

protected void Page_Load(object sender, EventArgs e)
{
    if (Request.From[Button1.UniqueID] != null)
    {
       // button1 click, handle it
       ...
    }
}