首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >条件渲染tr,使用ui建表:repeat

条件渲染tr,使用ui建表:repeat
EN

Stack Overflow用户
提问于 2013-06-19 21:30:07
回答 1查看 2.9K关注 0票数 0

我正在尝试使用ui:repeat在JSF中手动构建一个HTML表单。现在,我在"rendered“属性上遇到了一些麻烦。我的代码如下:

代码语言:javascript
复制
<ui:repeat varStatus="status" value="#{bean.keys}" var="key">
    <tr jsf:rendered="#{status.index%4==0}">
        <td id="#{key}">
             contents
        </td>
    </tr> <!--or even </tr  jsf:rendered="#{status.index%4==0}">-->
</ui:repeat>

我尝试有条件地呈现<tr>标记,但我想在每次迭代中无条件地呈现子元素<td>。我知道这不是JSF的标准行为,因为默认情况下它不会显示未呈现元素的子元素,但是有没有其他方法来实现这个要求呢?我也尝试过:

代码语言:javascript
复制
<tr>
    <ui:repeat varStatus="status" value="#{bean.keys}" var="key">
        <td id="#{key}">
             contents
        </td>
        <h:panelgroup rendered="#{status.index%4==0}"></tr><tr></h:panelgroup>
    </ui:repeat>
</tr>

但最后这段代码不会解析,因为结束是意外的(它需要h:panelgroup的结束标记)。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-06-19 21:50:31

将其作为转义的HTML发出。

代码语言:javascript
复制
<h:outputText value="&lt;/tr&gt;&lt;tr&gt;" escape="false" rendered="#{status.index%4==0}" />

escape="false"只是为了避免JSF再次转义它,作为XSS攻击预防的一部分,这将导致它最终成为&amp;lt;/tr&amp;gt;&amp;lt;tr&amp;gt;

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

https://stackoverflow.com/questions/17192537

复制
相关文章

相似问题

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