现在的位置: 首页 > 综合 > 正文

DataGridView如何调整列宽 (转)

2013年10月14日 ⁄ 综合 ⁄ 共 1743字 ⁄ 字号 评论关闭

最近在C#版看到有几个朋友询问DataGridView如何调整列宽的问题.我做了一个总结.发出来供大家参考 DataGridView有一个属性是AutoSizeColumnMode,他有几个枚举值:

AllCells 调整列宽,以适合该列中的所有单元格的内容,包括标题单元格。

AllCellsExceptHeader 调整列宽,以适合该列中的所有单元格的内容,不包括标题单元格。

ColumnHeader 调整列宽,以适合列标题单元格的内容。 DisplayedCells 调整列宽,以适合当前屏幕上显示的行的列中的所有单元格的内容,包括标题单元格。

DisplayedCellsExceptHeader 调整列宽,以适合当前屏幕上显示的行的列中的所有单元格的内容,不包括标题单元格。

Fill 调整列宽,使所有列的宽度正好填充控件的显示区域,只需要水平滚动保证列宽在 DataGridViewColumn.MinimumWidth 属性值以上。相对列宽由相对 DataGridViewColumn.FillWeight 属性值决定。

None 列宽不会自动调整。

NotSet 列的大小调整行为从DataGridView.AutoSizeColumnsMode 属性继承。

如果想要自动设置列宽.在这里就必须把DataGridView的值设置为Fill. 接下来,绑定数据源:this.dgvMain.DataSource = ds2.Tables[0]; 然后: this.dgvMain.Columns[0].FillWeight = 8; //第一列的相对宽度为8% this.dgvMain.Columns[1].FillWeight = 22; //第二列的相对宽度为22% this.dgvMain.Columns[2].FillWeight = 70; //第三列的相对宽度为70% 注意:这里的值是相对于DataGridView当前的总宽度的.所以窗体最大化和缩小的效果是不一样的.但比例不变 顺便提下如何给每列设置标头: 设置标题字段(先把ColumnsHeadersVisible设置为true) this.dgvMain.Columns[0].HeaderText = "编号"; this.dgvMain.Columns[1].HeaderText = "日期"; this.dgvMain.Columns[2].HeaderText = "标题"; ----------------------------- 还想介绍一下using()在连接数库代码中的用法。看到很多朋友没有使用过它。我强烈建议养成使用using的习惯。它帮我们管理数据库连接,非常安全简便 private DataSet GetConn() { string connstr = ConfigurationManager.ConnectionStrings["MySqlConnection"].ConnectionString; string sqlstr = "SELECT * FROM UserInfo"; DataSet ds = new DataSet(); using (SqlConnection conn = new SqlConnection(connstr)) { SqlCommand cmd = new SqlCommand(sqlstr, conn); cmd.CommandType = CommandType.Text; SqlDataAdapter ada = new SqlDataAdapter(); ada.SelectCommand = cmd; ada.Fill(ds); } return ds; } 这是这样的用法。它把我们连接数据库,执行SQL命令,使用适配器返回数据集的操作全部包含在内这样。我们不需要去关心它的conn的资源是否关闭。当我们不用到它时。系统自动帮我们安全关闭 而且,注意到了吗?我没有写conn.open() 是的。可以不写这句。但有个条件:当我们使用适配器的时候,就不用写open()。否则就要写上。 对了,如果大家有兴趣。可以去下载微软难得的开源DLL--SQLHelper 它把所有的数据库操作的方法全部封装在内。包括增删改查。我们只需要引用,调用。这可是官方的东东。值得一试。我看了下他的源码。里面也是采用的using()

【上篇】
【下篇】

抱歉!评论已关闭.