当前位置:首页 > Windows程序 > 正文

C# DataGridView 对指定行文字加粗实现阅读标记

2021-03-28 Windows程序

在使用DataGridView控件放置通知等信息时,会遇到标记“已读”、“未读”的问题。通过SQL语句查询出的结果中,“已读”、“未读”会被放在一个专门的字段(DataGridView的列)中用来标记这个 条目的阅读情况。本文的目标就是要做到在显示上区分当前用户已读和未读的条目。

1、准备工作

建立一个C#窗体应用程序,里面放置一个Dock属性设置为Full的DataGridView

2、程序代码

在Load函数中,,模拟生成了一个数据源,处理DataGridView显示状态的代码放在DataSourceChanged事件中,即每当DataSource重新被赋值时刷新DataGridView的显示状态。代码中按IsRead列的值判断该行数据是否为“已读”

using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Text.RegularExpressions; using System.Threading.Tasks; using System.Windows.Forms; namespace test {     public partial class FormMain : Form     {         public FormMain()         {             InitializeComponent();         }         private void FormMain_Load(object sender, EventArgs e)         {             //生成数据源             DataTable dtTestData = new DataTable();             dtTestData.Columns.Add("Title");             dtTestData.Columns.Add("Content");             dtTestData.Columns.Add("IsRead");             dtTestData.Rows.Add("标题1", "正文1", true);             dtTestData.Rows.Add("标题2", "正文2", false);             dtTestData.Rows.Add("标题3", "正文3", true);             dtTestData.Rows.Add("标题4", "正文4", false);             dtTestData.Rows.Add("标题5", "正文5", true);             this.dgvTestData.DataSource = dtTestData;         }         /// <summary>         /// 数据表内数据源发生变化         /// </summary>         /// <param name="sender"></param>         /// <param name="e"></param>         private void dgvTestData_DataSourceChanged(object sender, EventArgs e)         {             for (int i = 0; i < dgvTestData.Rows.Count; i++)             {                 string isRead = dgvTestData.Rows[i].Cells["IsRead"].Value.ToString();                 if (isRead.ToLower().Trim() == "true")                 {                     //TODO 已读处理                     dgvTestData.Rows[i].DefaultCellStyle.ForeColor = Color.Black;                     dgvTestData.Rows[i].DefaultCellStyle.BackColor = Color.White;                     dgvTestData.Rows[i].DefaultCellStyle.Font =                          new Font("宋体", 9F, FontStyle.Regular);                 }                 else                 {                     //TODO 未读处理                     dgvTestData.Rows[i].DefaultCellStyle.ForeColor = Color.Black;                     dgvTestData.Rows[i].DefaultCellStyle.BackColor = Color.White;                     dgvTestData.Rows[i].DefaultCellStyle.Font =                          new Font("宋体", 9F, FontStyle.Bold | FontStyle.Underline);                 }             }         }     } }

温馨提示: 本文由Jm博客推荐,转载请保留链接: https://www.jmwww.net/file/69103.html