Big*_*igJ 3 ajax jsf render primefaces
这是代码:
<h:form id="articleForm" >
<p:commandButton value="Select tags" ajax="true" >
<f:ajax execute="@form" render="@form :articleForm:tags" />
</p:commandButton>
<p:pickList id="tags" value="#{articleController.dualListModelForTags}" var="tag" itemLabel="#{tag.tag}" itemValue="#{tag}" converter="distinctTagConverter">
<f:facet name="sourceCaption">Distinct tags</f:facet>
<f:facet name="targetCaption">Connected tags</f:facet>
</p:pickList>
</h:form>
Run Code Online (Sandbox Code Playgroud)
单击命令按钮时,将调用并执行辅助bean中的getDualListModelForTags().在getDualListModelForTags()中我做了一些修改,所以我想要更新选项列表.但是不会再次呈现选项列表(id = tags).只有当我刷新页面时,才会对选项列表进行修改.
Bal*_*usC 13
PrimeFaces <p:commandButton>组件不能与之一起使用<f:ajax>.您需要使用按钮自己的ajax目标属性.而不是<f:ajax execute>你应该使用<p:commandButton process>.但是这已经默认为@form,所以你可以省略它.而不是<f:ajax render>你应该使用<p:commandButton update>.指定已经涵盖的客户端ID @form是不必要的,所以就@form足够了.此ajax="true"属性也是不必要的,因为它已经是默认值.
所以这应该做:
<p:commandButton value="Select tags" update="@form" />
Run Code Online (Sandbox Code Playgroud)
与具体问题无关,您在getter方法中执行业务工作.这是一个坏主意.action改为按钮的方法.您似乎也在使用会话范围的bean来查看作用域数据.这是一个坏主意.将bean放在视图范围中.
| 归档时间: |
|
| 查看次数: |
11547 次 |
| 最近记录: |