i have a grid views that generated columns through the code, and also ItemTemplate field from aspx, how can i clear columns generated from the code without clearing the template fields?
code from my previous post
TemplateField templateField = new TemplateField();
TemplateField uid = new TemplateField();
uid.HeaderText = "userid";
uid.ItemTemplate = new AddItemTemplate(ListItemType.Item, "userid");
GridView1.Columns.Add(uid);
for (int i = 0; i < dt.Columns.Count; i++)
{
BoundField boundField = new BoundField();
if (dt.Columns[i].ColumnName.ToString() != "userid")
{
boundField.DataField = dt.Columns[i].ColumnName.ToString();
boundField.HeaderText = dt.Columns[i].ColumnName.ToString();
GridView1.Columns.Add(boundField);
}
}
aspx
<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="false">
<Columns>
<asp:TemplateField>
<ItemTemplate>
<tr>
<td>
<div id="div<%# Eval("userid") %>" >
<asp:GridView ID="GridView2" AllowSorting="true" >
<Columns>
--code--
</Columns>
</asp:GridView>
</div>
</td>
</tr>
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
1) You can try rebinding to a different datasource altogether. One that returns all custom fields & other that returns only the Id
2) Easier way is to just hide the columns like YourGridView.Columns[0].Visible = false;