[英]How to determine which column user clicked on ASP.NET GridView
我在c.asp.net中有一个datagridview。 我正在使用此代码使行可选:
protected void OnRowDataBound(object sender, System.Web.UI.WebControls.GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.DataRow)
{
e.Row.Attributes["onclick"] = Page.ClientScript.GetPostBackClientHyperlink(gvTasks, "Select$" + e.Row.RowIndex);
e.Row.ToolTip = "Click to select this row.";
}
}
protected void OnSelectedIndexChanged(object sender, EventArgs e)
{
foreach (GridViewRow row in gvTasks.Rows)
{
if (row.RowIndex == gvTasks.SelectedIndex)
{
DataTable mydt = new DataTable();
mydt = (DataTable) Session["dt"];
Response.Redirect("EditTask.aspx?taskID=" + mydt.Rows[gvTasks.SelectedIndex].ItemArray[0].ToString()
+ "&agentID=" + mydt.Rows[gvTasks.SelectedIndex].ItemArray[1].ToString());
}
else
{
}
}
}
我的挑战是我添加了一个新的数据绑定列,这是我需要用户导航到的链接。 由于单击该行会自动将您带到某个页面(在本例中为“编辑任务”),因此如果您单击链接或该行的任何位置,最终都会带您进入“编辑任务”页面。
我需要确定单击了哪一列,以便添加额外的逻辑,如果特定列使用一个URL或所有其他URL,则使用另一个URL。 我没有在asp.net datagridview上找到selectedColumn属性。 确定所选列的最佳方法是什么。
GridView
没有允许选择列的内置机制,因此无法仅使用GridView
功能。
一种方法是在用户单击字段时在隐藏字段中设置列号,然后在OnSelectedIndexChanged
事件中检索此隐藏字段的值。
在gridview之外,插入一个新的hiddenField
<asp:hiddenField runat="server" id="hfColumnId" />
单击一行时,请使用JavaScript设置此值:
$('table#XXX td').click(function(){
var columnId = $(this).parent().children().index($(this));
$('#hfColumnId').val(columnId);
});
然后,在OnSelectedIndexChanged
事件中,可以使用以下方法检索columnId
Int32 columnId = Int32.Parse(this.hfColumnId.Value);
我对堆栈溢出的第一个答案:也许您需要做的是使用稍微不同的方法。 由于您的目标是让用户转到他们从数据网格单击的链接,因此您应该在运行时创建一个具有该链接的列。 您可以通过两种方式(以编程方式或asp)来实现。 将以编程方式回答
以编程方式:该代码在绑定网格时开始
GridView1.DataBind(); //绑定网格视图后,请执行以下操作
for (int i = 0; i < GridView1.Rows.Count; i++) { HyperLink hlContro = new HyperLink(); hlContro.NavigateUrl = "./newPage.aspx?ID=" + GridView1.Rows[i].Cells[3].Text; //This is where your url is being kept in the grid hlContro.Text = "Click me to go to the link"; GridView1.Rows[i].Cells[3].Controls.Add(hlContro);//adds the control to the gridview }
非常感谢那些在堆栈溢出时帮助我并使我今天也可以为您提供帮助的人。 希望我能帮上忙。 -Samcima
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.