PrimeFaces: p:cellEditor is not firing



我所拥有的:

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

问题:

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

我尝试了什么:

我创建了另一个基本的web应用程序,其中只有一个可编辑的<p:dataTable>(正如我所希望的(,在这个项目中,监听器会启动,我根本不知道有什么不同。为了简化这个问题,我不会添加其他项目的代码。

此外,我试图将(未(被接受的答案应用于这个问题,但也不起作用。

问题:

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

谢谢!

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;
    }
}

对解决方案或解决方法的注释:

在PrimeFaces展示中,建议使用<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>

Bean方法:

 public void onCellEdit(Item item) {
    //stuff
}

相关内容

  • 没有找到相关文章

最新更新