Ich habe eine spezifische Anforderung, wo ich ein dataTable
von onchange
Ereignis eines selectOneMenu
aktualisieren muss, aber es scheint, dass die DataTable nicht aktualisiert wird. Ich habe versucht, triggerChange()
Funktion zu verwenden, ohne Glück. Bitte finde den folgenden Code, den ich ausprobiert habe.Funktion triggerChange() funktioniert nicht in JSF?
xhtml
<p:selectOneMenu id="id" style="width:250px"
value="#{priceCharterMBean.traffic.id}"
required="true"
requiredMessage="Traffic is required"
filter="true"
filterMatchMode="startsWith"
widgetVar="w_menu"
onchange="updateTable();">
<p:ajax event="change" process="@this"
listener="#{priceCharterMBean.loadTEI}"
update="aTEModelList"
immediate="true"
partialSubmit="true" />
<f:selectItem itemLabel="Select" itemValue=""
noSelectionOption="true" />
<f:selectItems value="#{priceCharterMBean.trafficModelList}"
var="traffic" itemLabel="#{traffic.loadTrafficList}"
itemValue="#{traffic.id}" />
</p:selectOneMenu>
<p:dataTable style="width:350px" id="aTEModelList" var="aTEModelList" value="#{priceCharterMBean.aTEModelList}" rowKey="#{aTEModelList.id}">
<p:column style="display: none">
<f:facet name="header">
<h:outputText value="Expense Id" />
</f:facet>
<h:outputText id="expId" value="#{aTEModelList.id}" />
</p:column>
<p:column>
<f:facet name="header">
<h:outputText value="Expense Short Description" title="#{text.expenseshortdescription}" />
</f:facet>
<h:outputText id="expenseShortDesc" value="#{aTEModelList.expenseShortDescription}" />
</p:column>
<p:column>
<f:facet name="header">
<h:outputText value="Actual Expense Value" title="#{text.actualexpensevalue}" />
</f:facet>
<h:inputText id="actualTrafficExpense" maxlength="8" value="#{aTEModelList.actualTrafficExpense}" />
</p:column>
</p:dataTable>
Javascript
function updateTable() {
w_menu.triggerChange();
}
Die obige Funktion nicht aufgerufen wird erhalten, und die Werte in der Datatable gleich bleiben, obwohl, ändere ich den Wert in der Dropdown-Liste.
Vielen Dank, Hatem !! :) –
Gern geschehen. –