我在点击链接时调用了一个方法。以下代码可以很好地工作
<ui:repeat value="#{myBean.names}" var="name"
varStatus="idx">
<li>
<h:commandLink value="#{name.label}">
<f:ajax execute="@this" event="click" render="@all" listener="#{myBean.changeActiveName}" >
</f:ajax>
</h:commandLink>
</li>
</ui:repeat>
但是当我尝试将参数传递给Ajax调用时,它开始刷新整个页面
<ui:repeat value="#{myBean.names}" var="name"
varStatus="idx">
<li>
<h:commandLink value="#{name.label}">
<f:ajax execute="@this" event="click" render="@all" listener="#{myBean.changeActiveName}" >
<f:param name="idx" value="#{idx}" />
</f:ajax>
</h:commandLink>
</li>
</ui:repeat>
此代码有什么问题?
答案 0 :(得分:4)
<f:param>
必须是父UICommand
组件的子项,而不是<f:ajax>
的子项。
<h:commandLink value="#{name.label}">
<f:param name="idx" value="#{idx}" />
<f:ajax listener="#{myBean.changeActiveName}" render="@all" />
</h:commandLink>
(请注意,我删除了execute
和event
属性,因为您的定义已经是默认值;而且我想知道如何将整个IterationStatus
实例作为请求发送是有用的参数...也许您只是想发送索引?使用#{idx.index}
代替左右)
<h:dataTable>
,同样的答案同样适用于<ui:repeat>
)