- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在创建一个简单的购物车应用程序。在这种情况下,当用户从面板中选择一个项目并单击面板外部的“添加到购物车”按钮时,该项目必须显示在数据网格中。但不幸的是我无法实现它。索引.xhtml:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:p="http://primefaces.org/ui"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:ui="http://java.sun.com/jsf/facelets">
<f:view>
<h:head>
<div id="content">
<ui:insert name="content">
<ui:include src="/resources/templates/template.xhtml" />
</ui:insert>
</div>
</h:head>
<h:body>
<h:form id="index">
<br />
<p:growl id="msgs" showDetail="true" />
<p:tabView orientation="top" id="panel">
<p:tab title="Men" id="men">
<h:panelGrid id="MenPanel">
<ui:include src="/men1.xhtml"></ui:include>
</h:panelGrid>
</p:tab>
<p:tab title="Women" id="women">
<h:panelGrid id="WomenPanel">
<ui:include src="/women1.xhtml"></ui:include>
</h:panelGrid>
</p:tab>
</p:tabView>
<br />
<p:commandButton value="Add to Bag" update="dlg2" process="panel"
oncomplete="PF('dlg2').show()" />
<p:dialog header="Bag" modal="true" showEffect="clip"
widgetVar="dlg2" id="dlg2" resizable="false" width="300"
height="200">
<p:outputPanel id="bag">
<p:dataTable var="item" value="#{itemDataBean.userselectedItems}">
<p:column headerText="Item Id">
<h:outputText value="#{item.itemid}" />
</p:column>
<p:column headerText=" Item Name">
<h:outputText value="#{item.name}" />
</p:column>
<p:column headerText="Item Price">
<h:outputText value="#{item.price}" />
</p:column>
<p:column headerText="Item Price">
<h:outputText value="#{item.size}" />
</p:column>
</p:dataTable>
</p:outputPanel>
</p:dialog>
<p:commandButton value="Checkout" update="dlg2"
oncomplete="PF('dlg').show()" />
<p:dialog header="Cart" modal="true" showEffect="clip"
widgetVar="dlg" resizable="false" width="500" height="500" id="dlg">
<p:outputPanel id="cart">
<p:dataTable var="item" value="#{itemDataBean.cartlist}">
<p:column headerText="Item Id">
<h:outputText value="#{item.itemid}" />
</p:column>
<p:column headerText=" Item Name">
<h:outputText value="#{item.name}" />
</p:column>
<p:column headerText="Quantity">
<h:outputText value="1" />
</p:column>
<p:column headerText="Item Price">
<h:outputText value="#{item.price}" />
</p:column>
<p:columnGroup type="footer">
<p:row>
<p:column colspan="3" style="text-align:right"
footerText="Total Price:" />
<p:column footerText="#{itemData.total}" />
</p:row>
</p:columnGroup>
</p:dataTable>
</p:outputPanel>
</p:dialog>
</h:form>
</h:body>
</f:view>
</html>
men1.xhtml:
<h:form id="MenItemForm" prependId="false">
<p:outputPanel>
<p:outputLabel value="Select Category : ">
<br />
</p:outputLabel>
</p:outputPanel>
<p:selectManyCheckbox id="shopmen" value="#{itemDataBean.selectedMenItems}">
<br />
<f:selectItems value="#{itemDataBean.menItems}" var="item"
itemValue="#{item.itemid}" itemLabel="#{item.name}" />
<br />
</p:selectManyCheckbox>
<br />
<br />
</h:form>
Women1.xhtml:
<h:form id="womenItemForm" prependId="false">
<p:outputPanel>
<p:outputLabel value="Select Category : ">
<br />
</p:outputLabel>
</p:outputPanel>
<p:selectManyCheckbox id="shopwomen" value="#{itemDataBean.selectedWomenItems}">
<br />
<f:selectItems value="#{itemDataBean.womenItems}" var="item"
itemValue="#{item.itemid}" itemLabel="#{item.name}" />
<br />
</p:selectManyCheckbox>
<br />
<br />
</h:form>
和 bean 类:
/** * 获取UI数据的类 */
package com.shop.web;
import java.util.ArrayList;
import java.util.List;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;
import com.shop.data.Item;
/**
* @author svalsalan
*
*/
@ManagedBean(name = "itemDataBean")
@SessionScoped
public class ItemDataBean {
private List<Item> MenItems = new ArrayList<Item>();
private List<Item> WomenItems = new ArrayList<Item>();
private List<Item> Items = new ArrayList<Item>();
public List<String> selectedItems = new ArrayList<String>();
public List<String> selectedMenItems = new ArrayList<String>();
public List<String> selectedWomenItems = new ArrayList<String>();
public List<Item> userselectedItems = new ArrayList<Item>();
List<Item> Cartlist = new ArrayList<Item>();
public List<Item> getItems() {
Items = new ArrayList<Item>();
// set an initial value for the price
// Create items
Item Shirt = new Item(1, "Shirt", 100, "S");
Shirt.setItemid(1);
Item tshirt = new Item(1, "T-Shirt", 200, "M");
tshirt.setItemid(2);
Item jean = new Item(1, "Jeans", 300, "L");
jean.setItemid(3);
Item Dress = new Item(0, "Dress", 300, "S");
Dress.setItemid(4);
Item Tops = new Item(0, "Tops", 100, "S");
Tops.setItemid(5);
Item skirt = new Item(0, "Skirt", 200, "S");
skirt.setItemid(6);
// Add them to the list
Items.add(0, Shirt);
Items.add(1, tshirt);
Items.add(2, jean);
Items.add(3, Dress);
Items.add(4, Tops);
Items.add(5, skirt);
return Items;
}
/**
* @return the menItems
*/
public List<Item> getMenItems() {
MenItems.clear();
getItems();
for (int i = 0; i < Items.size(); i++) {
if (Items.get(i).getCategoryId() == 1) {
MenItems.add(Items.get(i));
}
}
return MenItems;
}
/**
* @return the womenItems
*/
public List<Item> getWomenItems() {
WomenItems.clear();
getItems();
for (int i = 0; i < Items.size(); i++) {
if (Items.get(i).getCategoryId() != 1) {
WomenItems.add(Items.get(i));
}
}
return WomenItems;
}
/**
* @param menItems
* the menItems to set
*/
public void setMenItems(List<Item> menItems) {
MenItems = menItems;
}
/**
* @param womenItems
* the womenItems to set
*/
public void setWomenItems(List<Item> womenItems) {
WomenItems = womenItems;
}
/**
* @return the items
*/
/**
* @param items
* the items to set
*/
public void setItems(List<Item> items) {
Items = items;
}
public List<String> getSelectedMenItems() {
return selectedMenItems;
}
/**
* @return the selectedWomenItems
*/
public List<String> getSelectedWomenItems() {
return selectedWomenItems;
}
/**
* @param selectedMenItems
* the selectedMenItems to set
*/
public void setSelectedMenItems(List<String> selectedMenItems) {
this.selectedMenItems = selectedMenItems;
System.out.println(selectedMenItems);
}
/**
* @param selectedWomenItems
* the selectedWomenItems to set
*/
public void setSelectedWomenItems(List<String> selectedWomenItems) {
this.selectedWomenItems = selectedWomenItems;
System.out.println(selectedWomenItems);
}
/**
* @return the selectedItems
*/
public List<String> getSelectedItems() {
this.selectedItems.clear();
selectedItems.addAll(getSelectedWomenItems());
selectedItems.addAll(getSelectedMenItems());
return selectedItems;
}
/**
* @param selectedItems
* the selectedItems to set
*/
public void setSelectedItems(List<String> selectedItems) {
this.selectedItems = selectedItems;
}
/**
* @return the userselectedItems
*/
public List<Item> getUserselectedItems() {
this.userselectedItems.clear();
// loop through the selectedItems array
for (String str : selectedItems) {
// each one item in the array, loop throug the list from
// getMenItem()
for (Item item : Items) {
// Match the ids' and store in a different list
if (str.matches(Integer.toString(item.getItemid()))) {
// add the items to the new list
this.userselectedItems.add(item);
}
}
// return the new list
}
return this.userselectedItems;
}
/**
* @param userselectedItems
* the userselectedItems to set
*/
public void setUserselectedItems(List<Item> userselectedItems) {
this.userselectedItems = userselectedItems;
}
/**
* @return the selectedMenItems
*/
/**
* @return the cartlist
*/
public List<Item> getCartlist() {
Cartlist.clear();
Cartlist.addAll(getUserselectedItems());
return Cartlist;
}
/**
* @param cartlist
* the cartlist to set
*/
public void setCartlist(List<Item> cartlist) {
Cartlist = cartlist;
}
/**
* @return the userselectedMenItems
*/
public int getTotal() {
int total = 0;
for (Item totalItemPrice : getCartlist()) {
total += totalItemPrice.getPrice();
}
return total;
}
}
最佳答案
我在这里注意到的第一件事是你应该避免嵌套表单(参见此处:How to use <h:form> in JSF page? Single form? Multiple forms? Nested forms?)
对于更新 html 中特定部分的问题,通常是这样的
update=":name_of_containing_form:id_of_element_to_update"
关于java - 如何使用其他页面的按钮更新面板 : primefaces,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32600701/
我想为每个条显示不同颜色的 primefaces 条形图。我得到的最接近的就像图像: 我想用不同的颜色来表示这些条,比如绿色代表“准时”,黄色代表“警告”,红色代表“逾期” 我尝试使用 model.s
我对 Primefaces 3 对话框的构造感到困惑。 我在 SO 中看到了具有这种模式的问题。表单在对话框之外。 但另一个问题有这个。 Primef
我尝试使用一个简单的gmap示例开始开发Web应用程序,但是它对我不起作用。 我使用了在网页上找到的示例电影收藏家。我只在template.html文件中包含了这个代码。 我收到此错误: javax.
我正在使用 primefaces 3.0。我有三个文本字段,其中任何一个都是必需的。我如何在 primefaces 中验证这一点。请帮忙..谢谢 最佳答案 通常,当在组件上使用自定义 f:valida
我正在尝试为 primefaces 选择列表创建自定义过滤器。当我按照手册中的说明进行操作时,我在 primefaces 的某处遇到了 TypeError。 我对picklist的定义 我的过滤
我正在努力处理primefaces日历。我需要的是,如果今天是 2011 年 7 月 28 日,我可以限制用户选择 7 月 28 日之前 1 年和 7 月 28 日之后 3 年的日期。 我查看了 pr
有没有办法删除 p:datatable 标题上的全选复选框。 我需要单个行上的复选框,而不是标题上的复选框。 最佳答案 这非常有效: .ui-chkbox.ui-chkbox-all.ui-widge
Primefaces 3.5,Mojarra 2.1.14。这是我的 PF 数据表,它包含一个名为“自动”的不可编辑 bool 列和可编辑的“标签”列:
我想在向导的最后一个选项卡上隐藏后退按钮。 我正在使用素面。它的解决方案是什么? 谢谢 最佳答案 您可以使用 jQuery 在客户端执行此操作: 假设您正在使用展示中的向导:http://www.pr
如果我在 PrimeFaces 数据表中设置属性“scrollable=true”,它可以垂直滚动。但是可以水平滚动这个表格吗? 最佳答案 Primefaces 支持在数据表上水平滚动。只需像这样指定
我有这个代码。在用户选择一行并关闭对话框之后,它将触发rowSelect事件。在我更新为primfaces 3.3(我安装了ver3.2)之前,它工作得很好。我在控制台中没有任何异常,当我调试时,我看
是否存在任何方法来设置 primefaces 的日历组件的年份列表? 最佳答案 对于年份列表,您可以使用 navigator="true" p:calendar 中素面的属性标记和年份范围 c-100
我正在使用 primefaces 3.2。我已经准备好了向导,可以在数据表的同一页面上插入用户信息。向导逐个选项卡获取信息并在确认选项卡上提交。它还将反射(reflect)在数据表的同一页面上。它运行
我有一个 p:treeTable,树内容都在一列中。该树是一个共享组件,因此我的某些页面需要列标题,而有些则不需要。在列标题为空的页面中,它为列标题创建一个空行,这是我不想要的。我确实想要列内容,只是
我使用的是primefaces 3.4,我在 p:overlaypanel 中有一个 p:calendar 。当我选择日期时,覆盖面板关闭(使用 Google Chrome 时)当我使用 Firefo
当我使用日历时,我将“timeOnly”设置为“true”,将“pattern”设置为“HH:mm a”。 当输入时间大于或等于“13:00 pm”时,日历每次获得焦点,都会 自动将时间更改为“23:
我也在尝试获取枚举“CityCodes.java”中定义的城市代码,这是我的枚举类,我的定义如下: public enum Cities { AL("Alabama","1"), AK("Alaska
在 PrimeFaces 展示页面上有一个简单的标题栏,适合实际主题。我的意思是此页面上的“欢迎来到 PrimeFaces 展示”文本:http://www.primefaces.org/showca
是否可以在 Primefaces 中创建垂直菜单栏? 我习惯了像 Ext-JS 这样简单的纯 AJax 框架,但到目前为止我还没有在 PF 中看到这样的组件。 谢谢, 乔 最佳答案 它被称为分层菜单。
是否可以设置 Primefaces 的 ScrollPanel 的滚动速度? Scrollpanel 在“ native ”模式下的滚动速度可以,但在“默认”模式下不行。 我使用的是 Primefac
我是一名优秀的程序员,十分优秀!