如上所述,我需要为
创建“动态”参数<ui:composition>
<h:link>
<h:outputText value="link with params" />
<ui:repeat var="parameter" value="#{bean.getCurrentParameter}"> //customClass
test: #{parameter.name} #{parameter.value} //output is fine
<f:param name="#{parameter.name}" value="#{parameter.value}" />
</ui:repeat>
</h:link>
</ui:composition>
遗憾的是,“test”正确返回所有值,但是当我悬停链接时,没有一个参数集(“page.xhtml”而不是“page.xhtml?param1 = ddd&amp; param2 = sss ... “)
为了解释我为什么需要这个,我想得到当前页面的所有参数并添加/删除一个(点击的链接是我要删除/添加的链接)。
我需要为每个链接生成自己的参数(当param1 = 1,2时,默认情况下,一个链接有例如“param1 = 1,2,3”(附加3),另一个链接有“param1 = 1” ,2,4“(追加4))
答案 0 :(得分:4)
经典taghandlers vs component tags问题。 <ui:repeat/>
是在构建视图树之后运行的组件标记,而<f:param/>
是在视图构建期间放置在视图树中的标记处理程序。这意味着<f:param/>
在<ui:repeat/>
进入页面之前被解析和处理。因此var="parameter"
在<f:param/>
需要时无法使用<c:forEach/>
。
要修复此问题,请改用<h:link>
<h:outputText value="link with params" />
<c:forEach var="parameter" items="#{bean.getCurrentParameter}">
test: #{parameter.name} #{parameter.value}
<f:param name="#{parameter.name}" value="#{parameter.value}" />
</c:forEach>
</h:link>
标记:
{{1}}