我正在尝试在DataTable中显示Hashmap,这是我正在尝试做的事情:我将有一些产品的选择菜单,数量的输入文本,添加的“ajaxified”添加按钮产品及其到地图的数量,以及一个提交按钮,显示包含DataTable的摘要对话框,其中包含两列:Product Name和Quantitiy。 我的Hashmap是
Map<Product,Integer> myMap = new HashMap<Product,Integer>();
对于ajaxified按钮和所有这些第一步,它们都在为我工作,我已经设置了所有内容并且地图正确地填充了剩下的所有数据。
提前致谢。
答案 0 :(得分:38)
您可以像这样创建类:
public class Product{
private int id;
private String productName;
private int quantitiy;
// add getters setters here
}
// add product id to map key
Map<Integer,Product> myMap = new HashMap<Integer,Product>();
public Map<Integer,Product> getProductMap() {
return myMap;
}
public List<Product> getProducts() {
return new ArrayList<Product>(myMap.values()_;
}
将数据表值添加到getProducts()List
否则,产品作为地图键,然后,
Map<Product,Integer> myMap = new HashMap<Product,Integer>();
public List<Map.Entry<Product, Integer>> getProducts() {
Set<Map.Entry<Product, Integer>> productSet =
myMap.entrySet();
return new ArrayList<Map.Entry<Product, Integer>>(productSet);
}
像这样编写primeface页面,
<p:dataTable value="#{productBean.products}" var="productEntry">
<p:column>
<h:outputText value="#{productEntry.key.productName}" />
</p:column>
<p:column>
<h:outputText value="#{productEntry.value}" />
</p:column>
</p:dataTable>