Problem:
I want to add headers in the middle of a gridview databind. I updated the DataTable to include headers and their correct positions(I’ve checked during debug, they’re there). On the new rows that contain headers, one of the unneeded fields (unneeded as in the header doesn’t need that information) has a flag called “Subheader” in it.
Background information:
So my datatable rows hold a server name, and the group the server belongs to. I updated the DataTable so it inserts a new row where the server name is the header text. The server group that this new row belongs to is “Subheader”. My datatable holds more information than what my gridview shows. My gridview only needs one column, but has a column with visibility=false; which holds the server group.
What I want to achieve:
So when I bind this datatable to the gridview I want all the non-header rows to be links that point to another location. All the data rows that are headers I want to just leave them as is.
Code:
private void CurrentServers_RowCreated(Object sender, GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.DataRow)
{
if(e.Row.Cells[1].Text != "Subheader")
{
e.Row.Cells[0].Text = "<a href='/EventViewer.aspx?m=" + e.Row.Cells[0].Text + "&s=&e=Application&r=25'>" + e.Row.Cells[0].Text + "</a>";
}
}
}
Questions:
This isn’t working. e.Row.Cells[1].Text != "Subheader" always returns true. In debugging I check the value of e.Row.Cells[1].Text and somewhere in there it has the information I need.
- Is this the correct event I should be handling?
- How do I access that data?
e.Row.Cells[1].Textande.Row.Cells[1].ToString()do not return the result that I want, even though when in debugging I can find the value I want ine.Row - I’ve tried finding exactly how this works but am unable to find answers. If my GridView only has columns for 2 datatable columns, will
e.Row.Cellsonly have the 2 cells that my gridview requires, or does this take place before it breaks apart the datatable (i.e. does it have all the columns that my datatable has)
Depending on how you bind your data and how you get server group, you could do the following:
In the item template where you’re showing content of nonheader row, instead of plain text use two placeholders, one will hold label for nonhyperlink text and another will hold hyperlink. You bind both controls to whatever text property you use. And set those placeholders’ visibility to
Eval("ServerGroup").ToString().ToLowerInvariant().Equals("subheader")and!Eval("ServerGroup").ToString().ToLowerInvariant().Equals("subheader"). That way you won’t have to write code to perform control manipulation and get away from using RowDataBound event all together.Let me know if this doesn’t make sense 🙂
EDIT: