我想对primefaces上的示例数据表做一点补充。我想添加另一个用于删除部分数据的列。如果汽车的颜色是白色,则设置为此条件。我正确地渲染了删除按钮,我检查了正在调用actionListener并从列表中删除汽车。但是,即使数据表反映在列表中,也不会更新数据表。每当我对数据表进行排序时,列表都会更新。我想按删除后立即更新。这就是我所拥有的。
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:c="http://java.sun.com/jsp/jstl/core"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:p="http://primefaces.org/ui">
<h:head>
</h:head>
<h:body>
<h:form>
<p:dataTable id="carTable" var="car" value="#{dtBasicView.cars}">
<f:facet name="header">
Car Table
</f:facet>
<p:column headerText="Id" sortBy="#{car.id}">
<h:outputText value="#{car.id}" />
</p:column>
<p:column headerText="Year" sortBy="#{car.year}">
<h:outputText value="#{car.year}" />
</p:column>
<p:column headerText="Brand" sortBy="#{car.brand}">
<h:outputText value="#{car.brand}" />
</p:column>
<p:column headerText="Color" sortBy="#{car.color}">
<h:outputText value="#{car.color}" />
</p:column>
<p:column headerText="Delete Option">
<p:commandLink actionListener="#{dtBasicView.deleteCar(car)}"
update="carTable" rendered="#{car.isWhite}" value="Delete" ajax="true">
<h:outputText value="Delete" />
</p:commandLink>
</p:column>
</p:dataTable>
</h:form>
</h:body>
</html>
这是java部分。
@ManagedBean(name="dtBasicView")
@ViewScoped
public class BasicView implements Serializable {
/**
*
*/
private static final long serialVersionUID = 1L;
private Car selectedCar;
private List<Car> cars;
private List<Car> oneHundredCars;
private int numberOfcars=0;
@ManagedProperty("#{carService}")
private CarService service;
@PostConstruct
public void init() {
oneHundredCars = service.createCars(10000);
}
public void setNumberOfcars(String num) {
this.numberOfcars = Integer.parseInt(num);
cars = oneHundredCars.subList(0, numberOfcars);
}
public List<Car> getCars() {
return cars;
}
public void setService(CarService service) {
this.service = service;
}
public Car getSelectedCar() {
return selectedCar;
}
public void setSelectedCar(Car selectedCar) {
this.selectedCar = selectedCar;
}
public boolean getIsEmpty() {
return cars == null || cars.isEmpty();
}
public void deleteCar(Car car) {
cars.remove(car);
}
}
答案 0 :(得分:1)
您可以尝试使用update="@form"
。看起来像旧版本的primefaces在从数据表中的动作更新数据表时会遇到错误。
或者您可以升级到最新的Primefaces。
答案 1 :(得分:0)
commandLink必须位于表单内,并将此标记过程添加到commandLink
<p:commandLink actionListener="#{dtBasicView.deleteCar(car)}"
update="carTable" rendered="#{car.isWhite}" value="Delete" ajax="true">
<h:outputText value="Delete" process="@this, tabla_carTable" /></p:commandLink>