如何让UpdatePanel适用于多个按钮?

问题描述 投票:0回答:1

我有一个有多个按钮的应用程序。我试图在每次单击按钮时保持页面不被重新加载(这会干扰其他控件),所以我将代码的主要部分包装在<asp:UpdatePanel><ContentTemplate></ContentTemplate></asp:UpdatePanel>中。我已经查看了单个按钮的多个解决方案,涉及在<Triggers><asp:AsyncPostBackTrigger>...之后使用</ContentTemplate>,但这不能解决我的问题。根据一些AjaxControlToolkit,我正在使用using AjaxControlToolkit;(我已将ModalPopExtender添加到我的C#文件中)以及UpdatePanel,这似乎会影响solutions的行为。没有发布整个应用程序(很长),这是当前代码(aspx和C#)的基本布局,以及我到目前为止所尝试的内容。对我做错了什么建议?

ASPX

<asp:UpdatePanel ID="UpdatePanel1" runat="server" UpdateMode="Conditional" ChildrenAsTriggers="true">
    <ContentTemplate>
        <div class="container" id="table_controls_section" style="margin-top: 20px; width: 100%;">
            <div class="row" style="width: 100%;">
                <table style="border-style:solid; border-color: darkblue; border-width:thin; border-bottom-width: 0px; width:100%;">                     
                    <tr>
                      <th style="text-align: center;">Requestor Info</th>
                    </tr>
                    <tr>
                      <td style="padding: 5px; text-align: center; width: 100%;">
                        <asp:Button ID="uxTicketHistoryButton" runat="server" Text="Show Ticket History"  style="color: blue;" OnClick="uxTicketHistoryButton_Click"/>&nbsp;
                         <asp:Button ID="uxUseContactInfoButton" runat="server" Text="Use Contact Info" style="color: blue;" OnClick="uxUseContactInfoButton_Click" />
                      </td>
                  </tr>
                </table>
            </div>
        </div>
    </ContentTemplate>
    <Triggers>
        <asp:AsyncPostBackTrigger ControlID="uxUseContactInfoButton" />
        <asp:AsyncPostBackTrigger ControlID="uxTicketHistoryButton" />
    </Triggers>
</asp:UpdatePanel> 

C#

using System;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using AjaxControlToolkit;
namespace BCA_TicketManagement
{
    public partial class Summary : Page
    {
       ....
      protected void uxTicketHistoryButton_Click(object sender, EventArgs e)
      { ....
      }
      protected void uxUseContactInfoButton_Click(object sender, EventArgs e)
      { ....
      }
    }
}

到目前为止我尝试过的事情:1)将using AjaxControlToolkit;添加到C#代码中。它也显示在我的参考文献中。 2)将UpdateMode="Conditional" ChildrenAsTriggers="true"添加到我的asp:UpdatePanel。也尝试改变ChildrenAsTriggers="false"。没有不同。 3)尝试通过使用UpdatePanel为该按钮添加<Triggers><asp:AsyncPostBackTrigger...>来让ControlID为单个按钮工作。没变。 4)将xmlns:asp="#unknown"添加到<asp:AsyncPostBackTrigger...>。引发错误AsyncPostBackTrigger has no property 'xmlns:asp="#unknown"'注意此页面加载在<form>using Master.site中的<asp:ContentPlaceHolder ID="ContentPlaceHolder1" runat="server">标记内。

c# asp.net button updatepanel page-refresh
1个回答
1
投票

您应该将EventName提供给Trigger,如以下示例所示:

<Triggers>
     <asp:AsyncPostBackTrigger ControlID="uxUseContactInfoButton" EventName="Click" />
     <asp:AsyncPostBackTrigger ControlID="uxTicketHistoryButton" EventName="Click" />
</Triggers>

我希望这能解决你的问题。

© www.soinside.com 2019 - 2024. All rights reserved.