今天又發現了一個很有用的東西,DataGridView的CellFormating事件
經常從數據庫查到的原始數據需要經過轉換之后顯示在客戶端,比如性別,“1”顯示“男”,“0”顯示“女”,為此經常將數據綁定到一個下拉框中才能顯示,這樣出現了非法數據,比如“2”的時候,就會拋出異常,為此,用CellFormating事件就可以利用事件在數據需要顯示的時候才將它轉換,而且這樣就有機會可以處理異常數據,例如要顯示如下DataTable的數據:
private void Form1_Load(object sender, EventArgs e) { DataTable dt = new DataTable(); dt.Columns.Add(new DataColumn("Id")); dt.Columns.Add(new DataColumn("Name")); dt.Columns.Add(new DataColumn("Bit")); dt.Rows.Add(new object[] { "1", "abcd", "0"}); dt.Rows.Add(new object[] { "2", "abcd", "1" }); dt.Rows.Add(new object[] { "3", "abcd", "0" }); dt.Rows.Add(new object[] { "4", "abcd", "1" }); dt.Rows.Add(new object[] { "5", "abcd", "1" }); dt.Rows.Add(new object[] { "6", "abcd", "0" }); dataGridView1.AutoGenerateColumns = false; dataGridView1.DataSource = dt; }
這時想要讓Bit顯示為“是“和”否”,只需要為DataGridView1訂閱事件CellFormating就可以處理數據了:
private void dataGridView1_CellFormatting(object sender, DataGridViewCellFormattingEventArgs e) { if (Column_bit.Index == e.ColumnIndex) { if (e.Value == null) { return; } if (e.Value.Equals("0")) { e.Value = "否"; } else { e.Value = "是"; } } }
原鏈接:http://blog.csdn.net/testcs_dn/article/details/37834063