JSF(Primefaces)ajax通过ID更新几个元素
还有一个关于JSF的问题。特别是Primefaces。
有id的ajax同时更新元素有以下问题。
如果页面上的元素一个接一个,则ajax更新执行正常:
<ui:repeat value="#{showProducts.inCart}" var="cart">
<td><p:spinner min="0" value="#{cart.count}" immediate="true">
<p:ajax process="@this" update="count,subTotal"/></p:spinner></td>
<td><h:outputText value="#{cart.totalPrice}" id="count"/></td>
<h:outputText value="#{showProducts.subTotal}" id="subTotal"/>
</ui:repeat>
这里id为“count”的元素首先出现,然后id为“subtotal”的元素变为第二个。
如果页面上的元素不是一个一个严格,那么具有“小计”id的第二个元素不会更新:
<ui:repeat value="#{showProducts.inCart}" var="cart">
<td><p:spinner min="0" value="#{cart.count}" immediate="true">
<p:ajax process="@this" update="count,subTotal"/></p:spinner></td>
<td><h:outputText value="#{cart.totalPrice}" id="count"/></td>
<td><h:outputText value="#{cart.place}" /></td>
</ui:repeat>
<h:outputText value="#{showProducts.subTotal}" id="subTotal"/>
这是正常的行为还是我错过了一些参数?
没有找到相关结果
已邀请:
1 个回复
蓄荣糖些
组件(
,
,
等)内,则需要指定“绝对”客户端ID。带有
的前缀(默认的
分隔符)从root开始。
确保在生成的HTML中检查实际值中的
组件的客户端ID。如果它也在内部,例如
,那么它的前缀也是它的客户端ID,你需要相应地修复它。
更推荐使用ID的空格分隔,因为
不支持逗号分隔,否则启动器会混淆。