GridView RowCommand未触发

The*_*eek 0 c# vb.net asp.net gridview

我无法弄清楚为什么RowCommand没有触发.奇怪的是,我在页面上有一个不同的GridView,它的RowCommand没有问题,所以我不知道问题是什么.

我有以下代码:

JavaScript的

function displayPayees() {
        $('#payeeList').css("display", "block");
        $('#payeeList').dialog({
            modal: true,
            draggable: false,
            resizable: false,
            maxHeight: 600,
            width: 800,
            position: { my: "center top", at: "center top+15%", of: window }
        }); 
    }
Run Code Online (Sandbox Code Playgroud)

.aspx

<div id="payeeList" title="Available Payees" style="display:none;">
    <asp:GridView ID="gvPayees" runat="server" Visible="true" AutoGenerateColumns="false" ShowHeaderWhenEmpty="true" Width="100%" AllowSorting="True" OnRowCommand="gvPayees_RowCommand" CssClass="table table-striped">
        <HeaderStyle Font-Bold="True" ForeColor="White" Height="15px" BackColor="#46596b" Wrap="False"></HeaderStyle>
        <Columns>
            <asp:BoundField DataField="TaxID" HeaderText="Tax ID"></asp:BoundField>
            <asp:BoundField DataField="Name" HeaderText="Name"></asp:BoundField>
            <asp:BoundField DataField="Address1" HeaderText="Address"></asp:BoundField>
            <asp:BoundField DataField="Address2" HeaderText="Address 2"></asp:BoundField>
            <asp:BoundField DataField="City" HeaderText="City"></asp:BoundField>
            <asp:BoundField DataField="State" HeaderText="State"></asp:BoundField>
            <asp:BoundField DataField="Zip" HeaderText="Zip"></asp:BoundField>
            <asp:TemplateField HeaderText="">
                <ItemStyle HorizontalAlign="Center" VerticalAlign="Middle" />
                <ItemTemplate>
                    <asp:Button ID="btnSelectPayee" runat="server" Text="Select" CssClass="btn btn-default home-btn btn-sm" CausesValidation="false" CommandName="SelectPayee" CommandArgument='<%# Eval("TaxID") & "~" & Eval("Name") & "~" & Eval("Address1") & "~" & Eval("Address2") & "~" & Eval("City") & "~" & Eval("State") & "~" & Eval("Zip") %>' />
                </ItemTemplate>
            </asp:TemplateField>
        </Columns>
    </asp:GridView>
</div>
Run Code Online (Sandbox Code Playgroud)

代码背后

Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
    If Not Page.IsPostBack Then
            BindDetails()
        End If
End Sub

Protected Sub gvPayees_RowCommand(ByVal sender As Object, ByVal e As GridViewCommandEventArgs)
    Throw New Exception("Hello?") 'Test code
End Sub
Run Code Online (Sandbox Code Playgroud)

更新:

我注意到将GridView移出其中div会导致RowCommand正常启动.

我正在使用jQuery UI将GridView放入一个对话框中,以便在单击按钮时显示.我有display: none关于包含,div以便GridView不可见,直到按钮单击,我认为这可能是我的问题的根源.我在这里更新我的代码以反映这一点.

如何在div不阻止RowCommand正确触发的情况下隐藏直到按钮单击?

VDW*_*WWD 5

将它从a更改Button为a LinkButton,它将起作用.

<ItemTemplate>
    <asp:LinkButton ID="btnSelectPayee" runat="server" CommandName="SelectPayee" 
        CommandArgument='<%# Eval("TaxID") %>' >Select</asp:LinkButton>
</ItemTemplate>
Run Code Online (Sandbox Code Playgroud)

显然,jQuery UI对话框将模式放在</form>标记之外,因此普通按钮不再起作用.但是LinkBut​​tons使用JavaScript来执行PostBack,它们仍然在框架中注册.

在此输入图像描述