前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【C#】DataGridView 数据绑定的一些细节

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

作者头像
丹枫无迹
发布2020-08-18 14:24:35
1.4K0
发布2020-08-18 14:24:35
举报
文章被收录于专栏:学无止境

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

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

数据绑定

代码语言:javascript
复制
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 被修改的实例。

阻止自动创建列

代码语言:javascript
复制
dgvEmployees.AutoGenerateColumns = false;

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

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

自定义数据格式

代码语言:javascript
复制
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));
    }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-08-16 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 数据绑定
  • 阻止自动创建列
  • 自定义数据格式
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档