希望标题不是太神秘......
我们遇到的问题是我们从一些Java List中生成了一堆输入控件(h:inputOneMenu
,h:inputText
等。
工作正常除了要求是这些输入在运行中验证。同样不是那么难,除了因为在循环中生成控件,唯一可能的reRender操作基本上是整个表单或每个循环迭代周围的a4j:outputPanel
,这基本上是相同的。
现在上面两个解决方案在技术上有效,但是它们具有令人讨厌的副作用,即重新渲染所有页面控件,这使得页面感觉非常抽搐和笨重。我们想要阻止这种情况发生,理想情况下,获得reRendered的唯一控件是发送ajax更新/验证的控件。
基本上这是我们的页面代码:
<ui:repeat value="#{seam-outjected-list}" var="item">
<a4j:outputPanel selfRendered="true">
<h:inputText value=#{item.value}>
<a4j:support event="onblur" ajaxSingle="true" />
</h:inputText>
</a4j:outputPanel>
</ui:repeat>
我遗漏了一些根据项目呈现不同控件的东西。
正如您所看到的那样,我们当前正在使用a4j:outputPanel
解决方案,因此每次更新任何循环生成的控件时,所有控件都会重新生成。
如果有人有任何想法,请提前致谢。
答案 0 :(得分:1)
我首先想到的是,您应该尝试使用<ui:repeat>
替换<a4j:repeat>
,并利用ajaxKeys
属性仅重新调整某些行。
这个组件的主要区别 来自其他的迭代组件 图书馆是一个特殊的“ajaxKeys” 属性。该属性定义行 在Ajax之后更新的密钥 请求。结果变得更容易 更新几个子组件 单独而不更新整体 页。