我似乎无法找到一个易于使用的.net本地方法来获取.net winforms上的Comboboxes以显示一个值并根据选择返回另一个值而不创建我自己的帮助类,知道winforms是将在您放入其中的对象上显示ToString方法。
这就是我现在正在做的事情,非常一般。首先,创建帮助程序类。
Public Class ListItem
Public Value As Object
Public DisplayString As String
Public Sub New(ByVal NewValue As Object, ByVal NewDisplayString As String)
Value = NewValue
DisplayString = NewDisplayString
End Sub
Public Overrides Function ToString() As String
Return DisplayString
End Function
End Class
然后,从集合或其他任何东西加载组合框。
For Each o as WhateverObject In CollectionIwantToaddItemsFrom
li = New ListItem(o.ValueToReturn, o.ValueToDisplay)
Me.ComboBox1.Items.Add(li)
Next
最后,使用对象
Private Sub ComboBox1_SelectedIndexChanged(ByVal sender As Object, ByVal e As EventArgs) Handles ComboBox1.SelectedIndexChanged
if me.combobox1.selecteditem is nothing then exit sub
Dim li As ListItem = me.ComboBox1.SelectedItem
Dim o as object = li.value
'do stuff with o.
end sub
我确信在我正在寻找的框架中,我最好使用一些东西。它是什么?
答案 0 :(得分:6)
这有点像黑客,但这意味着你不必编写自己的Name-Value对类 - 这不是什么大不了的事(可能在框架中已经有了更好的东西)。但你可以做的是使用DictionaryEntry类 - 它实际上是一个名称值对。将项添加到列表中,然后使用组合框上的DataMember和ValueMember属性绑定到DictionaryEntry类的键和值属性。像这样:
var list = new List<System.Collections.DictionaryEntry>();
list.Add(new System.Collections.DictionaryEntry("one", 1));
list.Add(new System.Collections.DictionaryEntry("two", 2));
list.Add(new System.Collections.DictionaryEntry("three", 3));
comboBox1.DataSource = list;
comboBox1.DisplayMember = "Key";
comboBox1.ValueMember = "Value";
刚才意识到你更喜欢vb方言。以下内容对VB也是如此: - )
Dim list As List(Of DictionaryEntry)
list = New List(Of DictionaryEntry)
list.Add(New DictionaryEntry("One", 1))
list.Add(New DictionaryEntry("Two", 2))
list.Add(New DictionaryEntry("Three", 3))
ComboBox1.DataSource = list
ComboBox1.DisplayMember = "Key"
ComboBox1.ValueMember = "Value"
答案 1 :(得分:1)
由于缺乏对应用程序架构的更好理解,您可能采取了一种很好的方法。
通常,我将组合框绑定到重写.ToString()方法的DAL对象。这提供了基本相同的功能,但我必须重新组合在组合中选择的任何内容以获得“值”(通常是与实体的PK相对应的属性)。
答案 2 :(得分:0)
通常,您放置在Items集合中的对象将拥有自己的ToString(),它以可呈现的形式呈现对象。
但是,如果您希望为对象显示完全不相关的字符串,那么您将必须按照正确的方式进行。
答案 3 :(得分:0)
我通常最终会创建一个数据表并将此数据表设置为组合框的数据源。然后我将DisplayMember设置为我想要显示的列,将ValueMember设置为我想要返回的值。除了数据表之外,可能还有更好的东西,但这些是我在需要这个功能时使用的。