C# checklistbox控件用法总结(怎样得到多选的值,以及动态加载数据)

本文总结了C#中checklistbox控件的使用技巧,包括如何获取用户的多选值以及如何从数据库动态加载数据。对于需要在C#应用中实现类似功能的开发者,这篇内容提供了实用的指导。
摘要由CSDN通过智能技术生成
 
一般认为:foreach (object obj in checkedListBox1.SelectedItems)即可遍历选中的值。
其实这里遍历的只是高亮的值并不是打勾的值。遍历打勾的值要用下面的代码:
for (int i = 0; i < checkedListBox1.Items.Count; i++)
{
    if (checkedListBox1.GetItemChecked(i))
    {
        MessageBox.Show(checkedListBox1.GetItemText(checkedListBox1.Items[i]));
    }
}
参考:
最近用到checklistbox控件,在使用其过程中,花了较多的时间,这里我收集了其相关的代码段,希望对大家有所帮助。
1.
添加项
checkedListBox1.Items.Add("蓝色");
checkedListBox1.Items.Add("红色");
checkedListBox1.Items.Add("黄色");
2.
判断第i项是否选中,选中为true,否则为false
if(checkedListBox1.GetItemChecked(i))
{
     return true;
}
else
{
     return false;
}
3.
设置第i项是否选中
checkedListBox1.SetItemChecked(i, true);  //true改为false为没有选中。
4.
设置全选
添加一个名为select_all的checkbox控件,由其控制checkedListBox是全选还是全不选。
private void select_all_CheckedChanged(object sender, EventArgs e)
{
     if(select_all.Checked)
{
          for (int j = 0; j < checkedListBox1.Items.Count; j++)
   
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CheckListBox控件本身不支持每个选项加入多行的文本。每个选项在CheckListBox中默认只能显示单行文本。 如果你想要在CheckListBox中显示多行文本,你可以考虑以下两种方法: 1. 自定义绘制:你可以继承CheckListBox控件并自定义绘制。在绘制过程中,可以根据每个选项的内容进行换行处理,并将文本绘制在多个行上。这样就可以实现每个选项显示多行文本的效果。但是这种方法需要自己处理绘制逻辑,比较复杂。 2. 使用自定义控件:如果你需要在每个选项中显示复杂的多行文本,可以考虑使用自定义控件来替代CheckListBox。例如,你可以使用DataGridView控件,将每个选项作为DataGridView的行,并在每个单元格中显示多行文本。这样可以更灵活地处理每个选项的内容和布局。 以下是使用DataGridView控件实现每个选项显示多行文本的示例代码: ```csharp using System.Windows.Forms; // 创建一个DataGridView控件 DataGridView dataGridView1 = new DataGridView(); dataGridView1.Dock = DockStyle.Fill; // 添加列 dataGridView1.Columns.Add("Column1", "选项"); // 设置DataGridView的行高模式为自动调整 dataGridView1.AutoSizeRowsMode = DataGridViewAutoSizeRowsMode.AllCells; // 添加行并设置每个单元格的 dataGridView1.Rows.Add("第一行\r\n第二行"); dataGridView1.Rows.Add("第一行\r\n第二行\r\n第三行"); // 将DataGridView控件添加到窗体中 this.Controls.Add(dataGridView1); ``` 使用DataGridView控件可以实现每个选项显示多行文本的效果,并且可以更方便地进行布局和样式的调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值