PrimeFaces:p:cellEditor没有触发

时间:2015-07-21 13:34:21

标签: java jsf primefaces

我有什么:

基本数据表,为简单起见,仅显示某个客户订单的项目数量。

问题:

当我点击单元格时,<p:inputText>出现,我可以输入一个数字(例如:3)。当我按enter时,旧号码(例如:42)会出现在<h:outputText>中。如果再次单击该单元格,则会再次显示已编辑的编号(3)。最重要的是,public void onCellEdit(CellEditEvent event)方法不会被触发。

我做了什么:

我创建了另一个基本的网络应用程序,其中只有一个可编辑的<p:dataTable>(我想要它),在这个项目中,监听器会触发,我根本就没有得到不同的东西。为了简化这个问题,我不会添加其他项目的代码。

此外,我已尝试将(未)接受的答案应用于this问题,但它也无效。

问题:

为什么听众不会开火?可能是什么原因(或原因)?是的,我是初学者,所以任何提示都会非常受欢迎。

谢谢!

xhtml与表格

<ui:composition xmlns="http://www.w3.org/1999/xhtml"
            xmlns:ui="http://java.sun.com/jsf/facelets"
            xmlns:h="http://java.sun.com/jsf/html"
            xmlns:p="http://primefaces.org/ui"
            xmlns:f="http://java.sun.com/jsf/core"
            template="/templates/template.xhtml">

<ui:define name="metadata"/>
<ui:define name="content">

    <h:form id="lastOrders">

        <p:dataTable id="orders" 
                     var="item"
                     value="#{editController.items}"
                     emptyMessage="Der Kunde hat noch keine Aufträge!" 
                     style="size: 30px"
                     editable="true" 
                     editMode="cell">

            <p:ajax event="cellEdit" listener="#{editController.onCellEdit}" update=":mainForm:lastOrders:orders"/>

            <f:facet name="header"> 
                <p:outputPanel>
                    <h:outputText value="#{userController.customer.name}" />
                </p:outputPanel>
                <p:outputPanel>
                    <h:outputText value="#{oldOrdersController.order.date}">
                        <f:convertDateTime pattern="dd.MM.yy" />
                    </h:outputText>
                </p:outputPanel>
            </f:facet>

            <p:column  headerText="Amount">
                <p:cellEditor>
                    <f:facet name="output">
                        <h:outputText value="#{item.amount}"/>
                    </f:facet>
                    <f:facet name="input">
                        <p:inputText id="modelInput" value="#{item.amount}"/>
                    </f:facet>
                </p:cellEditor>
            </p:column>
        </p:dataTable>
    </h:form>
</ui:define>

这是EditController

package com.forall.laundry.controller.edit;

import com.forall.laundry.controller.OldOrdersController;
import com.forall.laundry.model.Item;
import com.forall.laundry.service.ItemService;
import com.forall.laundry.service.ProductService;
import java.io.Serializable;
import java.util.List;
import javax.annotation.PostConstruct;
import javax.ejb.EJB;
import javax.faces.view.ViewScoped;
import javax.inject.Inject;
import javax.inject.Named;
import org.primefaces.event.CellEditEvent;

    @Named
    @ViewScoped
    public class EditController implements Serializable{

    @EJB
    private ItemService itemService;

    @EJB
    private ProductService productService;

    @Inject
    private OldOrdersController oc;

    private List<Item> items;

    @PostConstruct
    public void init(){
        items = itemService.getItemsFrom(oc.getOrder());
    }

    public void onCellEdit(CellEditEvent event) {
        System.out.println("TEST"); // NOT FIRED (i know sysout is not good but no matter what I do here, nothing happens.
    }

    public ItemService getItemService() {
        return itemService;
    }

    public void setItemService(ItemService itemService) {
        this.itemService = itemService;
    }

    public OldOrdersController getOc() {
        return oc;
    }

    public void setOc(OldOrdersController oc) {
        this.oc = oc;
    }

    public List<Item> getItems() {
        return items;
    }

    public void setItems(List<Item> items) {
        this.items = items;
    }

    public ProductService getProductService() {
        return productService;
    }

    public void setProductService(ProductService productService) {
        this.productService = productService;
    }
}

1 个答案:

答案 0 :(得分:0)

对解决方案或解决方法的评论:

在PrimeFaces showcase中,建议使用<p:ajax event="cellEdit" listener="#{dtEditView.onCellEdit}" update=":form:msgs" />,但由于我不知道的原因,事件未被触发,并且未调用onCellEdit方法。因此,我研究了其他火灾事件的方法,我最终得到了下面的解决方案,其中我传递了被更改的对象本身,而不是事件。 我仍然不知道为什么原始代码不起作用。

段:

<p:column headerText="Produkt">
                <p:cellEditor>
                    <f:facet name="output">
                        <h:outputText value="#{item.name}"/>
                    </f:facet>
                    <f:facet name="input">
                        <h:inputText id="modelInput" value="#{item.name}">
                            <f:ajax execute="modelInput" event="change" listener="#{editController.onCellEdit(item)}" render=":mainForm:lastOrders:orders"/>
                        </h:inputText>
                    </f:facet>
                </p:cellEditor>
            </p:column>

豆方法:

 public void onCellEdit(Item item) {

    //stuff
}