在 C# 3.5 中使用组合框显示 LinQ 查询的结果。当 LinQ 查询返回匿名类型时,如何设置 ComboBox 的 SelectedItem 属性?
我按照这些行设置 ComboBox 的数据源:
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
};
我实际使用的匿名类型比那个更复杂,但足以解释。
最佳答案
如何将其转换为列表,然后从中选择正确的列表。由于 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;
关于c# - 将 ComboBox 的 SelectedItem 属性与 Linq 匿名类型一起使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/530482/