4

在 C# 3.5 中使用 ComboBox 来显示 LinQ 查询的结果。当 LinQ 查询返回匿名类型时,如何设置 ComboBox 的 SelectedItem 属性?

我按照以下几行设置 ComboBox 的 DataSource:

comboBox1.DataSource = from p in db.products
                       select p;
comboBox1.DisplayMember = "Name";
comboBox1.ValueMember = "ProductId";

如果我这样做,我可以通过执行以下操作来选择所选项目:

comboBox1.SelectedItem = (from p in db.products 
                          where p.ProductId = 5 
                          select p).First();

问题是我想用匿名类型结果填充 ComboBox,例如:

comboBox1.DataSource = from p in db.products
                       select new
                       {
                           p.ProductId,
                           p.Name
                       };

我实际使用的匿名类型比那更复杂,但足以解释。

4

2 回答 2

2

如何将其转换为列表,然后从中选择正确的列表。由于 SelectedItem 似乎不起作用,您可能想尝试设置 SelectedValue。

var productList = (from p in db.products
                   select new {
                      ProductId = p.ProductID,
                      Name = p.Name
                   }).ToList();

comboBox1.DataSource = productList;
comboBox1.DisplayMember = "Name";
comboBox1.ValueMember = "ProductId";
comboBox1.SelectedValue = 5;
于 2009-02-09T23:21:46.133 回答
0

这应该可以解决问题

var list = (from p in db.products
              select new {
                             p.ProductId,
                             p.Name
                           }).ToList();
comboBox1.DataSource = list;
comboBox1.SelectedItem = list[0];
于 2009-02-09T23:11:27.263 回答