带值和ID的Vaadin ComboBox [英] Vaadin ComboBox with values and IDs
问题描述
我定义了一个 ComboBox
,允许用户从他的联系人列表中选择一个联系人。 ComboBox显示联系人姓名,但不能真正用于映射到真实联系人:需要联系人ID。我的问题是,我不知道如何用链接的值和ID填充 Vaadin
ComboBox
,但只显示
I have defined a ComboBox
which allows the user to select a contact from his contact list. The ComboBox is showing the contact name, but that can not really be used to map to the real contact: the contact ID is needed. My problem is that I do not know how to populate the Vaadin
ComboBox
with linked values and IDs, but only showing the values.
// Add all organization contacts to the drop-down
for (Contact contact : organizationContacts) {
contactName = contact.getName();
contactId = contact.getId();
_logger.debug("Adding contactName=" + contactName + " contactId=" + contactId + " to person with id=" + personId);
contactNameCombo.addItem(contactName);
}
// Add the contact of this person, and select it in the drop-down
contactName = person.getContact().getName();
contactId = person.getContact().getId();
contactNameCombo.addItem(contactName);
contactNameCombo.setValue(contactName);
正如你在上面的代码中可以看到的,我添加了 contactName
到 ComboBox
,但我不知道如何添加 contactId
As you can see in the code above, I am adding the contactName
to the ComboBox
, but I do not know how to add also the contactId
so that I can know later, from the selected entry, which ID must be used to update the database.
推荐答案
有几种方法来处理这里:最灵活的是配置combobox使用命名属性作为标题。
有关详情,请参见 Vaadin选择项目。
There are several ways to approach this : the most flexible here is to configure the combobox to use a named property as a caption. See Book Of Vaadin on Selecting Items for more details.
// Set the caption mode to read the caption directly
// from the 'name' property of the item
contactNameCombo.setItemCaptionMode(Select.ITEM_CAPTION_MODE_PROPERTY);
contactNameCombo.setItemCaptionPropertyId("name");
// Add all organization contacts to the drop-down
for (Contact contact : organizationContacts) {
contactName = contact.getName();
contactId = contact.getId();
_logger.debug("Adding contactName=" + contactName + " contactId=" + contactId + " to person with id=" + personId);
// Note : the itemId of the item is the contactId
Item item = contactNameCombo.addItem(contactId);
item.getProperty("name").setValue(contactName)
}
// Add the contact of this person, and select it in the drop-down
contactName = person.getContact().getName();
contactId = person.getContact().getId();
Item item = contactNameCombo.addItem(contactId);
item.getProperty("name").setValue(contactName)
// Using the itemId (which = contactId) to select the given contact
contactNameCombo.setValue(contactId);
这篇关于带值和ID的Vaadin ComboBox的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!