UpdatePanel での最初の部分ポストバック後に Button.Click イベントが失われる

StackOverflow https://stackoverflow.com/questions/180366

質問

UserControl のインスタンスが 1 つあるページがあり、そのインスタンス自体に UpdatePanel が 1 つあります。UpdatePanel 内には、いくつかの Button コントロールがあります。これらのコントロールの Click イベントは、UserControl の Init イベントの分離コードに関連付けられています。

最初に押したボタンの Click イベントは毎回問題なく発生します。その後、1 つのボタン (SearchButton) の Click イベントのみを取得し、残りは無視されます。以下にコントロールのコードを含めました。簡潔にするためにクリック イベント ハンドラー メソッドを除外しましたが、これらはすべて標準の「void Button_Click(object sender, EventArgs e)」の種類です。何か案は?

<asp:UpdatePanel ID="PickerUpdatePanel" runat="server" UpdateMode="Conditional">
    <ContentTemplate>
        <asp:Panel ID="Container" runat="server">
            <div>
                <asp:TextBox ID="PickerResults" runat="server" style="margin-right: 3px;" SkinID="Plain" />
                <asp:Image
                    ID="LaunchPopup" runat="server" ImageUrl="~/images/icons/user_manage.png" 
                    ImageAlign="Top" BorderColor="#294254" BorderStyle="Dotted" BorderWidth="1px" 
                    Height="20px" Width="20px" style="cursor: pointer;" />
            </div>
            <asp:Panel ID="PickerPanel" runat="server" DefaultButton="OKButton" CssClass="popupDialog" style="height: 227px; width: 400px; padding: 5px; display: none;">
                <asp:Panel runat="server" id="ContactPickerSearchParams" style="margin-bottom: 3px;" DefaultButton="SearchButton">
                    Search: <asp:TextBox ID="SearchTerms" runat="server" style="margin-right: 3px;" Width="266px" SkinID="Plain" />
                    <asp:Button ID="SearchButton" runat="server" Text="Go" Width="60px" SkinID="Plain" />
                </asp:Panel>
                <asp:ListBox ID="SearchResults" runat="server" Height="150px" Width="100%" SelectionMode="Multiple" style="margin-bottom: 3px;" />
                <asp:Button ID="AddButton" runat="server" Text="Add >>" style="margin-right: 3px;" Width="60px" SkinID="Plain" />
                <asp:TextBox ID="ChosenPeople" runat="server" Width="325px" SkinID="Plain" />
                <div style="float: left;">
                    <asp:Button ID="AddNewContact" runat="server" SkinID="Plain" Width="150px" Text="New Contact" />
                </div>
                <div style="text-align: right;">
                    <asp:Button ID="OKButton" runat="server" Text="Ok" SkinID="Plain" Width="100px" />
                </div>
                <input id="SelectedContacts" runat="server" visible="false" />
            </asp:Panel>
            <ajax:PopupControlExtender ID="PickerPopEx" runat="server" PopupControlID="PickerPanel" TargetControlID="LaunchPopup" Position="Bottom" />
        </asp:Panel>
   </ContentTemplate>
   <Triggers>
        <asp:AsyncPostBackTrigger ControlID="AddButton" EventName="Click" />
        <asp:AsyncPostBackTrigger ControlID="SearchButton" EventName="Click" />
        <asp:AsyncPostBackTrigger ControlID="AddNewContact" EventName="Click" />
    </Triggers>
</asp:UpdatePanel>

public partial class ContactPicker : System.Web.UI.UserControl
{
    protected void Page_Init(object sender, EventArgs e)
    {
        SearchButton.Click += new EventHandler(SearchButton_Click);
        AddButton.Click += new EventHandler(AddButton_Click);
        OKButton.Click += new EventHandler(OKButton_Click);
    }

    // Other code left out
}
役に立ちましたか?

解決

UseSubmitBehavior =&quot; false&quot;を追加すると、ボタンの定義に私の問題を解決しました。その最初のボタンクリックがなぜ機能したのかはまだわかりません。

他のヒント

これの最も可能性の高い理由は、.Netがコントロールの変更のために生成するクライアントIDです。これらは動的に割り当てられ、ポストバック/部分的なポストバック間で変更される可能性があります。

コントロールがパネルに動的に追加されている場合、ボタンのIDがポストバック間で異なる可能性があり、.Netはクリックイベントをコード内の正しいイベントハンドラーに結び付けることができません。

私の場合は、 LinkButton 以内 dgPatients_ItemDataBound を使用したイベント ハンドラ PostBackUrl 財産。

変えた瞬間に LinkButtonHyperLink, 、問題は解決しました。

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top