gridview隱藏列的幾種方法
如果要對gridview的某個列根據條件隱藏或者隱藏不必要的列
一、簡單方法:
GridViewBrand為gridview控制元件,要對第3列進行現在,就可以在gridview資料繫結完成之後這樣寫:
if (...)
{
GridViewBrand.Columns[2].Visible = false;
}
目前我覺得這是最簡潔的方法。二、在RowCreated事件中書寫如下程式碼:
void GridView1_RowCreated(object sender, GridViewRowEventArgs e)
if (e.Row.RowType == DataControlRowType.DataRow ||
e.Row.RowType == DataControlRowType.Header)
{
e.Row.Cells[0].Visible = false; //如果想使第1列不可見,則將它的可見性設為false
}
//可以根據需要設定更多的列}
因為在RowCreated事件(隱藏)在繫結時候發生,所以這樣就即能將資料繫結到列上,又隱藏了該
列.所以可以訪問到隱藏列的值。
三、另外一個可以將資料繫結到GridView控制元件的方法:
Public void myTestFunction()
string conString="....";//省略string sqlquery="...";//省略SqlConnection con = new SqlConnection(conString);
SqlDataAdapter da = new SqlDataAdapter(sqlquery, con);
DataSet ds = new DataSet();
da.Fill(ds);
ds.Tables[0].Columns[0].ColumnMapping = MappingType.Hidden;
GridView1.DataSouce = ds.Tables[0];
GridView1.DataBind() ;
四、據說可以通過 FooterStyle-CssClass、 HeaderStyle-CssClass、 ItemStyle-CssClass樣式
控制來隱藏,但我今天沒有測試出來,如果有誰做過,請告訴我。謝謝。
五.自己總結的隱藏列在if (!IsPostBack)中寫
GridView1.Columns[10].Visible = false;
顯示:使用CheckBoxList使其AutoPostBack="True" 然後在
protected void CheckBoxList1_SelectedIndexChanged(object sender, EventArgs e)
{
if (this.CheckBoxList1.Items[0].Selected==true)
{
GridView1.Columns[10].Visible = true;
}
if (this.CheckBoxList1.Items[0].Selected == false)
{
GridView1.Columns[10].Visible = false;
}
}