多年不写 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
进行 Add
和 Remove
操作,界面会自动更新。更新数据,如果直接对 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)); }}
【C#】DataGridView 数据绑定的一些细节玩转账号前后台、 线下沙龙、 盘古集团、 最新破解版JS 插件Jungle+Scout+Pro汉化破解版、 出口这些国家的注意了!否则会引起货物滞留!、 机会来了!欧洲老牌电商平台首次向中国卖家开放!、 厦漳跨海大桥怎么去?、 参团旅游有什么好处?、 团队旅游、散客旅游和自助游有什么区别?、
没有评论:
发表评论