C# · 12月 26, 2021

c# – 条件DataGridView格式

我有一个DataGridView.我将它的.DataSource属性设置为我自己的对象的BindingList:一个BindingList< IChessItem>

然后我为它创建了一些列

DataGridViewText@R_153_2419@Column descColumn = new DataGridViewText@R_153_2419@Column(); descColumn.DataPropertyName = “Description”; descColumn.HeaderText = “Description”; descColumn.Width = 300; DataGridViewText@R_153_2419@Column gameIDColumn = new DataGridViewText@R_153_2419@Column(); gameIDColumn.DataPropertyName = “GameID”; gameIDColumn.HeaderText = “Game ID”; gameIDColumn.Width = 60; dataGrid.Columns.Add(descColumn); dataGrid.Columns.Add(gameIDColumn);

我的问题是..我想根据我的BindingList的另一个字段中的数据来颜色一列GREEN.我该怎么做?

我不是真的要显示这个字段,我只想对其中的数据采取行动.

在我的情况下,IChessItem的一个字段显示该记录是否是新的,并且我想对datagridview中的其他字段进行颜色反映.

解决方法 您可以使用DataGridView的“CellFormatting”事件. DataGridViewCellFormattingEventArgs包含绑定当前单元格的行和列的索引.我希望我的代码示例对你有意义: private void dataGridView1_CellFormatting(object sender,DataGridViewCellFormattingEventArgs e){ // Compare the column to the column you want to format if (this.dataGridView1.Columns[e.ColumnIndex].Name == “ColumnName”) { //get the IChessitem you are currently binding,using the index of the current row to access the datasource IChessItem item = sourceList[e.RowIndex]; //check the condition if (item == condition) { e.CellStyle.BackColor = Color.Green; } }}