首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JSF循环reRender

JSF循环reRender
EN

Stack Overflow用户
提问于 2009-07-20 21:34:28
回答 1查看 2.1K关注 0票数 0

希望标题不是太神秘..。

我们面临的问题是,我们从一些Java列表中生成了一组输入控件(h:inputOneMenuh:inputText等)。

工作正常,只是要求这些输入动态验证。同样,也不是很难,只是当在循环中生成控件时,唯一可能的reRender操作基本上是整个表单或每个循环迭代周围的一个a4j:outputPanel,这基本上是相同的事情。

现在,上述两种解决方案在技术上是可行的,但它们具有reRendering的不良副作用,所有的页面控件都会使页面感到非常棘手和笨重。我们希望阻止这种情况发生,因此理想情况下,获得reRendered的唯一控件是发送ajax更新/验证的控件。

基本上这是我们的页面代码:

代码语言:javascript
复制
<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解决方案,所以每次更新任何循环生成的控件时,所有控件都是reRendered。

如果有人有任何想法,请提前感谢。

EN

回答 1

Stack Overflow用户

发布于 2009-07-21 10:06:14

我的第一个想法是,您应该尝试用一个<ui:repeat>替换您的<a4j:repeat>,并利用ajaxKeys属性只对特定的行进行reRender。

来自理查医生

这个组件与其他库的迭代组件的主要区别是一个特殊的"ajaxKeys“属性。此属性定义在Ajax请求之后更新的行键。因此,在不更新整个页面的情况下,可以更容易地单独更新几个子组件。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1156088

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档