欢迎光临
我的个人博客网站

【C#】DataGridView 数据绑定的一些细节

多年不写 Winform 了,突然要做一个 winform 项目,各种不顺手,各种百度。

DataGridView 数据绑定的一些细节问题,记录备查。

数据绑定

BindingList<EmployeeVO> dataSource;  private async void FrmEmployeeInfo_Load(object sender, System.EventArgs e) {     List<EmployeeVO> employees = await employeeApi.GetList();      dataSource = new BindingList<EmployeeVO>(employees);      dgvEmployees.DataSource = dataSource; } 

绑定数据后,添加删除行,直接对 dataSource 进行 AddRemove 操作,界面会自动更新。更新数据,如果直接对 dataSource 中的元素属性进行修改,界面不会刷新,需要点击修改的元素,才会刷新。要立即刷新,可以用一个新的实例替换掉 dataSource 被修改的实例。

阻止自动创建列

dgvEmployees.AutoGenerateColumns = false; 

如果实例中有些列不想显示,就需要阻止自动创建列。

另外,当有 Link 等列时,如果设置此属性,Link 列的 Index 会被排在 TextBox 列之前,导致 ColumnIndex 错乱。

自定义数据格式

private void dgvEmployees_CellFormatting(object sender, DataGridViewCellFormattingEventArgs e) {     if (dgvEmployees.Columns[e.ColumnIndex].HeaderText == "技能")     {         List<SkillVO> skills = e.Value as List<SkillVO>;          e.Value = string.Join(", ", skills.Select(s => s.Name));     } } 
赞(0) 打赏
未经允许不得转载:张拓的天空 » 【C#】DataGridView 数据绑定的一些细节
分享到: 更多 (0)

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

专业的IT技术经验分享 更专业 更方便

联系我们本站主机

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏