在C#winform布局的時候,我們拖一個datagridview到窗體上面,將datagridview調整為適合窗體的大小,但是我們運行之后,點擊最大化按鈕的時候,卻發現datagridview的大小沒有隨着窗體的大小而變化,影響窗體的整個布局效果,這時候可以設置一下datagridview的相應屬性就可以實現,將Anchor的屬性設置為TOP,BOTTOM,LEFT,RIGHT即可實現datagridview隨窗體的大小而改變
而對於如何使整個表格填滿控件問題(如下圖)
可以采取以下兩個辦法:
(1)代碼:假設在form上有一個datagirdview,然后form_load事件中有下列代碼。
private void Form1_Load(object sender, EventArgs e) { DataTable dt = new DataTable(); dt.Columns.Add("name", typeof(string)); dt.Columns.Add("age", typeof(string)); dt.Columns.Add("sex", typeof(string)); dt.Columns.Add("birth", typeof(string)); //假設這里綁定了4列的datatable this.dataGridView1.DataSource = dt;//綁定 this.dataGridView1.RowHeadersVisible = false;//datagridview前面的空白部分去除 this.dataGridView1.ScrollBars = ScrollBars.None;//滾動條去除 this.dataGridView1.Width = this.dataGridView1.Columns[0].HeaderCell.Size.Width * 4;//根據column[0]的headercell的width計算整個datagridview的寬度 }
private void Form1_Load(object sender, EventArgs e) { DataTable dt = new DataTable(); dt.Columns.Add("name", typeof(string)); dt.Columns.Add("age", typeof(string)); dt.Columns.Add("sex", typeof(string)); //假設這里綁定了3列的datatable this.dataGridView1.DataSource = dt; int width = this.dataGridView1.Width; int avgWidth = width / dt.Columns.Count;//求出每一列的header寬度 for (int i = 0; i < this.dataGridView1.Columns.Count; i++) { this.dataGridView1.Columns[i].Width = avgWidth;//設置每一列的寬度 } }
(2)控件屬性
屬性AutoSizeColumnsMode設置為Fill