我有一个 GridView
你可以点击一行,它应该调用SelectedIndexChanged
方法(根据选择的行更新页面的另一部分)。我以前做过类似的事情并且它有效,但我似乎无法获得 SelectedIndexChanged
由于某种原因被调用的部分。
该页面保存在母版页中,母版页具有 form runat="server"
标签,和一个 <asp:ScriptManager>
标签
我正在使用 e.Row.Attributes.Add("onclick", ClientScript.GetPostBackClientHyperlink(Me.gridMessages, "Select$" & e.Row.RowIndex))
允许 SelectedIndexChanged
通过点击行上的任意位置来触发。
为了检查代码是否能正常工作,我添加了一个 CommandField
用SelectButton
并且成功触发,但我更愿意找到一个解决方案而不必使用它。
代码如下 - 任何帮助将不胜感激。谢谢
GridView
:
<asp:UpdatePanel ID="UpdatePanel1" runat="server" UpdateMode="Always">
<ContentTemplate>
<asp:HiddenField runat="server" ID="hdnScrollPosition" />
<asp:GridView ID="gridMessages" runat="server" CssClass="gridView" AutoGenerateColumns="False"
AllowPaging="true" GridLines="None" PageSize="10" ShowHeader="True"
EmptyDataText="--No Messages Received--" Width="100%">
<Columns>
<asp:TemplateField HeaderText="Messages Received" HeaderStyle-HorizontalAlign="Left" HeaderStyle-CssClass="headerClass">
<ItemTemplate>
....
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
</ContentTemplate>
</asp:UpdatePanel>
代码隐藏:
Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
If Not IsPostBack Then
Me.gridMessages.DataSource = ...
Me.gridMessages.DataBind()
End If
End Sub
Protected Sub gridMessages_RowDataBound(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.GridViewRowEventArgs) Handles gridMessages.RowDataBound
If e.Row.RowType = DataControlRowType.DataRow Then
e.Row.Attributes.Add("onmouseover", "this.style.backgroundColor='#D2E6F8'")
e.Row.Attributes.Add("onmouseout", "this.style.backgroundColor='#ffffff'")
e.Row.Attributes.Add("onclick", "saveScrollPosition(); " & ClientScript.GetPostBackClientHyperlink(Me.gridMessages, "Select$" & e.Row.RowIndex))
End If
End Sub
SelectedIndexChanged
(从不触发):
Protected Sub gridMessages_SelectedIndexChanged(ByVal sender As Object, ByVal e As System.EventArgs) Handles gridMessages.SelectedIndexChanged
Response.Redirect("test.aspx")
End Sub
最佳答案
您不需要定义为 SelectButton
的列 CommandField
吗?然后,您的标记将类似于:
<asp:UpdatePanel ID="UpdatePanel1" runat="server" UpdateMode="Always">
<ContentTemplate>
<asp:HiddenField runat="server" ID="hdnScrollPosition" />
<asp:GridView ID="gridMessages" runat="server" CssClass="gridView" AutoGenerateColumns="False"
AllowPaging="true" GridLines="None" PageSize="10" ShowHeader="True"
EmptyDataText="--No Messages Received--" Width="100%">
<Columns>
<asp:CommandField ShowSelectButton="true" ButtonType="Button" />
<asp:TemplateField HeaderText="Messages Received" HeaderStyle-HorizontalAlign="Left" HeaderStyle-CssClass="headerClass">
<ItemTemplate>
....
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
</ContentTemplate>
</asp:UpdatePanel>
你没有问这个,但我总是觉得有必要提到这两行这样的事情:
e.Row.Attributes.Add("onmouseover", "this.style.backgroundColor='#D2E6F8'")
e.Row.Attributes.Add("onmouseout", "this.style.backgroundColor='#ffffff'")
这是一种代码味道。这不是一个坏的问题,但是将 JavaScript 属性与 VB/C# 代码混合是您现在应该改掉的习惯。如果您需要执行此类操作,请将 CssClass
属性添加到您的 GridView 并在 CSS 中定义这些操作(如果 CSS 没有足够的事件供您使用,则使用 JavaScript/jQuery)。
编辑:
根据我们在评论中的讨论,这看起来与 GridView 的修改方式不一致。它可能与页面/事件生命周期有关(ASP.NET 正确连接事件为时已晚?),最好的选择是从 SelectedIndexChanged
事件切换到 SelectedIndexChanging
.
关于asp.net - 为什么我的 GridView SelectedIndexChanged 事件没有触发?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8358641/