c#(winform)中自定义ListItem类方便ComboBox和ListBox添加项完全解决(DropDownList 和Combox 数据绑定的常用方法)

68 篇文章 0 订阅
1 篇文章 0 订阅





     刚开始用.net 的winform开发,发现好些控件都很难用,可能是不熟悉的原因吧,这不,一个给ComboBox添加项的问题就搞的我很头疼,我要同时给一个项添加名字和值,怎么都没法加,查了查资料,又自己汇总测试了下,终于全部搞定了,现把完整的方案写下。
        用comboBox的数据绑定的方法很简单,建一个数据源,绑定到ComboBox上,然后指定DisplayMember和 ValueMember就可以了。但是感
觉好不灵活哦,如果我要在ComboBox上再添加一项,那怎么办?Web里面有ListItem, winform里面怎么没有了?感觉真是不爽,网上找了个方法,自己添加一个ListItem类,然后add到items里面,感觉还不错,有点象web 里面的用法了,可是问题又来了,添加的第一项怎么变成类名了?不是我给它赋的名字,其他项又都没有问题。于是又查到说,“因为combobox的 Item.ADD(一个任意类型的变量),而显示的时候调用的是这个变量的ToString()方法,如果这个类没有重载ToString(),那么显示的结果就是命名空间   +   类名”,于是加上重载的ToString()方法,好了,至此,我终于可以很方便的来给ComboBox和ListBox添加项了。


首先添加类ListItem:
/// 
/// 选择项类,用于ComboBox或者ListBox添加项
/// 
public class ListItem

private string id = string.Empty;
private string name = string.Empty;
//可以根据自己的需求继续添加,如:private Int32 m_Index;

    public ListItem()    
    {   } 
public ListItem(string sid, string sname) 

   id = sid; 
   name = sname; 
}
public override string ToString()   
{   
   return this.name;
}
public string ID 

   get
   {
    return this.id;
   } 
   set
   {
    this.id = value;
   } 

public string Name 

   get
   {
    return this.name;
   } 
   set
   {
    this.name = value;
   } 

}
然后在程序中使用:
ListItem item = new ListItem("我是值", "我是名字");
this.lbChoiceRoom.Items.Add(item);
this.lbChoiceRoom.DisplayMember = "Name";
this.lbChoiceRoom.ValueMember = "ID";
或者:
            for (int i = 0; i < 7; i++)
            {
                ListItem li = new ListItem(); //还可以直接添加ListItem li =

new ListItem("id","name")
    li.ID = i.ToString();
                //[li.Index = i;]
                li.Name = i.ToString();
                comboBox1.Items.Add(li);
            }


MessageBox.Show(((ListItem)comboBox3.SelectedItem).ID.ToString()); 
就可以取values了




DropDownList 和Combox 数据绑定的常用方法

web       DropDownList绑定数据源的几种方式
 第一种
                this.ddltype.DataTextField = "btName";//显示的值
                this.ddltype.DataValueField = "btId";//获取dropdownlist中的值
                ddltype.DataSource = service.GetBusinessTypeAll("");
                this.ddltype.DataBind();
第二种
                 DataTable dt_GetBusinessName = service.GetBusinessTypeAll("");

                //表中无数据的话直接返回
                if (dt_GetBusinessName == null)
                    return;

                for (int i = 0; i < dt_GetBusinessName.Rows.Count; i++)
                {
                    ddltype.Items.Add(new ListItem(dt_GetBusinessName.Rows[i]["btName"].ToString().Trim(),//显示的值
                    dt_GetBusinessName.Rows[i]["btId"].ToString().Trim()));
                }s
                ddltype.Items.Add(new ListItem("全部", "-1"));
                ddltype.Text = "全部";

如何选中DropDownList1中的值用

  protected void DropDownList1_SelectedIndexChanged(object sender, EventArgs e)
    {
        this.TextBox1.Text = this.DropDownList1.SelectedItem.Text.ToString();
    }

windows     combox的手写数据绑定
            第一种:
                cCombox1.DisplayMember = "btName";//显示的值
                cCombox1.ValueMember = "btId";
                cCombox1.DataSource = _manageService.GetBusinessTypeAll(this.UserInfo.uNote1);
            第二种:
                 DataTable dt_GetStateByName = _financeService.GetStateByNam(UserInfo.uNote1);

                //表中无数据的话直接返回
                if (dt_GetStateByName == null)
                    return;

                for (int i = 0; i < dt_GetStateByName.Rows.Count; i++)
                {
                       cbType2.Items.Add(new ListItem(dt_GetStateByName.Rows[i]["osState"].Trim(),
                       dt_GetStateByName.Rows[i]["osName"].ToString().Trim()));//显示的值
                }
                cbType2.Items.Add(new ListItem("-1", "全部"));
                cbType2.Text = "全部";


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
您可以使用以下步骤在C# WinForm动态ComboBox下拉列表: 1. 在您的WinForm添加一个ComboBox控件。 2. 在您的代码,使用ADO.NET连接到您的数据库。 3. 编写一个SQL查询语句来检索您需要添加ComboBox下拉列表数据。 4. 使用DataAdapter和DataSet对象来执行查询并将结果保存在一个DataTable对象。 5. 使用ComboBox控件的DataSource属性将DataTable对象与ComboBox控件。 6. 使用ComboBox控件的DisplayMember属性将您希望显示在ComboBox下拉列表数据列的名称指为字符串。 7. 使用ComboBox控件的ValueMember属性将您希望在选择ComboBox下拉列表的项目时返回的值的数据列的名称指为字符串。 以下是一个示例代码,可以将ComboBox下拉列表动态数据数据: ```csharp using System.Data.SqlClient; // 创建数据库连接 SqlConnection connection = new SqlConnection("Server=myServerAddress;Database=myDataBase;User Id=myUsername;Password=myPassword;"); // 创建SQL查询语句 string query = "SELECT ID, Name FROM MyTable"; // 创建DataAdapter和DataSet对象 SqlDataAdapter adapter = new SqlDataAdapter(query, connection); DataSet dataSet = new DataSet(); // 执行查询并将结果保存在DataTable对象 adapter.Fill(dataSet, "MyTable"); // 将DataTable对象与ComboBox控件 comboBox1.DataSource = dataSet.Tables["MyTable"]; // 指ComboBox控件显示的数据列的名称 comboBox1.DisplayMember = "Name"; // 指在选择ComboBox下拉列表的项目时返回的值的数据列的名称 comboBox1.ValueMember = "ID"; ``` 当您运行此代码时,ComboBox下拉列表将显示从数据检索到的所有项目的名称,并且选择任何项目时,ComboBox控件将返回该项目的ID作为值。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值