我在我的 JSF 应用程序中使用 JSTL 标记。通过某些操作,我需要重新构建组件树,就好像它是初始构建一样。我目前的症状是组件关联不正确、id 重复以及其他与过时组件有关的问题。这是使用在构建阶段使用的 c:foreach (不能使用重复标签,请参阅示例链接)标签。
我的理解是可以强制重建,但我无法找到发生的位置或方式。我对在客户端或服务器上启动的解决方案持开放态度。
有关我正在使用的代码示例,请参阅 Richfaces 中动态选项卡上的此页面。
http://in.relation.to/Bloggers/UsingDynamicallyCreatedRichFacesTabPanelForSearchResults
注意:使用 ui:repeat 或 a4j:repeat 是不可行的。有关详细信息,请参阅示例页面。
其他注意事项:应用程序 bean 是 session 范围的,其中的数据必须是,而不是组件树状态。
更新 这个问题直接针对 this article 中提出的问题。和第一条评论。我不知道如何在第一条评论中实际解决问题,而接受的答案让我想到了它。
最佳答案
我认为陈旧的组件不是问题。重复 ID 尤其是使用 <c:forEach>
的副作用。标签。这是因为 <c:forEach>
将多次将任何子组件添加到组件树中,并且每次都会尝试使用相同的 ID(与 <ui:repeat>
不同)。这显然会导致重复的 ID(您会注意到在链接到的示例中它们没有在 <c:forEach>
标记中指定任何 ID)。
我不确定“ View 构建阶段”是什么意思。如果您查看 JSF documentation ,你会看到没有这样的阶段。无论如何,当您使用 <ui:repeat>
,只要您用于执行搜索的 AJAX 调用重新呈现 rich:tabPanel
那么它应该可以工作。
他们引用 <ui:repeat>
的原因不工作是:
You could not use repeat components(neither ui:repeat nor a4j:repeat) for that because they work during page render time and do not create components in JSF tree but just iterate the same instance.
在他们的例子中,他们使用了:
...
<a4j:commandButton action="#{capitalsBean.search}" value="Search" reRender="output" id="search"/>
...
<a4j:outputPanel id="output">
<rich:tabPanel id="tapPanel" width="700" rendered="#{not empty capitalsBean.foundCapitals}">
<c:forEach items="#{capitalsBean.foundCapitals}" var="cap">
...
如果您指定
reRender="output"
在搜索 a4j:commandButton
tapPanel
如何不会出现“页面呈现时间”? ??总之,使用
<ui:repeat>
, JSTL 和 JSF 通常不是很好的伙伴。编辑:我应该先这样做,因为我没有使用
rich:tabPanel
的经验。但是 <ui:repeat>
,似乎不能与 rich:tabPanel
一起使用(但不是因为您链接到的示例中所述的原因,因此我感到困惑)。不要使用 <c:forEach>
不过,使用组件绑定(bind)到 rich:tabPanel
.
关于richfaces - 如何使用 JSTL 在 JSF 1.2 页面中强制构建阶段?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6298189/