在vb.net / winforms中,如何将哈希表绑定到下拉列表或任何其他数据源驱动的控件?
答案 0 :(得分:4)
只需使用下拉列表的数据源属性
即可 DropDownList dd = new DropDownList();
Hashtable mycountries = New Hashtable();
mycountries.Add("N","Norway");
mycountries.Add("S","Sweden");
mycountries.Add("F","France");
mycountries.Add("I","Italy");
dd.DataSource=mycountries;
dd.DataValueField="Key";
dd.DataTextField="Value";
dd.DataBind();
答案 1 :(得分:2)
这是winforms,wpf还是asp.net? [更新:啊...... winforms ;-p]
winforms希望数据为IList
(或间接地,通过IListSource
) - 所以我猜测(从评论中)你正在使用winforms。没有内置的类字典集合实现IList
,但说实话并不重要:如果你是数据绑定,那么卷可能相当小,所以常规列表应该没问题。
最佳选项类似于List<T>
或BindingList<T>
,其中T
包含您要绑定的所有属性。这是一个选择吗?如果你坚持使用1.1(因为你提到HashTable
而不是Dictionary<,>
),那么请使用ArrayList
。
示例(在C#中):
class MyData
{
public int Key { get; set; }
public string Text { get; set; }
}
[STAThread]
static void Main()
{
var data = new List<MyData>
{
new MyData { Key = 1, Text = "abc"},
new MyData { Key = 2, Text = "def"},
new MyData { Key = 3, Text = "ghi"},
};
ComboBox cbo = new ComboBox
{
DataSource = data,
DisplayMember = "Text",
ValueMember = "Key"
};
cbo.SelectedValueChanged += delegate {
Debug.WriteLine(cbo.SelectedValue);
};
Application.Run(new Form {Controls = {cbo}});
}
答案 2 :(得分:1)
名为Order的给定对象的示例:
List<Order> list = new List<Order>{};
foreach (Order o in OOS.AppVars.FinalizedOrders.Values)
{
list.Add(o);
}
this.comboBox_Orders.DataSource = list;
this.comboBox_Orders.DisplayMember = "Description";
这很酷的是,您可以将数据作为原始对象从列表中取出(而不仅仅是asp.net中的值字段)。
Order order = (Order)this.comboBox_Orders.SelectedValue;
答案 3 :(得分:0)
myCtrl.DataSource = myHashtable
myCtrl.DataBind()
可绑定控件的示例源:
<itemtemplate>
<%# DataBinder.Eval(Container.DataItem, "Key", "<td>{0}</td>") %>
<%# DataBinder.Eval(Container.DataItem, "Value", "<td>${0:f2}</td>") %>
</itemtemplate>
答案 4 :(得分:0)
而且,如果您碰巧使用Dictionary作为数据源,则可以使用
MyDDL.Datasouce = myDict.ToList();
它会将其转换为列表类型。
答案 5 :(得分:0)
使用.tolist。它也适用于从实体框架中的视图/存储过程中获得的返回复杂类型