我有一个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
答案 0 :(得分:4)
您是否需要将CommandField
列定义为SelectButton
?然后,您的标记看起来像:
<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#代码混合是一种你应该突破的习惯。如果您需要执行此类操作,请向GridView添加CssClass
属性,并在CSS中定义这些操作(如果CSS没有足够的事件,则在JavaScript / jQuery中定义)。
修改强>
根据我们在评论中的讨论,这看起来与GridView的修改方式不一致。它可能与页面/事件生命周期有关(不知何故,ASP.NET正确地连接事件已经太迟了?),这里你最好的选择是从SelectedIndexChanged
事件切换到{ {1}}。
答案 1 :(得分:1)
我一直在努力解决同样的问题......
它可能在您的方案中不起作用(或者根本不是一件好事)但是请尝试为页面设置EnableEventValidation="false"
。这对我来说是不同的。使用上述SelectedIndexChanged
或SelectedIndexChanging
事件进行工作。
答案 2 :(得分:0)
使用此:
e.Row.Attributes["onclick"]=ClientScript.GetPostBackEventReference(this.grvDetails,"Select$"+e.Row.RowIndex.ToString());