mar*_*osh 24 jsf facelets jsf-2 uirepeat
如何仅使用标准标签(ui:,h:etc)重复JSF中某些内容的输出?换句话说 - 如何在JSF中执行以下PHP代码?我马上想利用ui:repeat它,但它需要收集 - 我只有号码.
for ($i = 0; $i < 10; $i++) {
echo "<div>content</div>";
}
Run Code Online (Sandbox Code Playgroud)
Bal*_*usC 40
要么使用<c:forEach>(真的,将JSTL与JSF混合有时不受欢迎,但这不应该在您的特定情况下造成伤害,因为您似乎想要"静态地"创建视图;它不依赖于任何动态变量):
xmlns:c="http://java.sun.com/jsp/jstl/core"
...
<c:forEach begin="1" end="10">
<div>content</div>
</c:forEach>
Run Code Online (Sandbox Code Playgroud)
或者创建一个EL函数来创建一个虚拟数组<ui:repeat>:
package com.example.util;
public final class Functions {
private Functions() {
//
}
public static Object[] createArray(int size) {
return new Object[size];
}
}
Run Code Online (Sandbox Code Playgroud)
注册地址/WEB-INF/util.taglib.xml:
<?xml version="1.0" encoding="UTF-8"?>
<facelet-taglib
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-facelettaglibrary_2_0.xsd"
version="2.0">
<namespace>http://example.com/util/functions</namespace>
<function>
<function-name>createArray</function-name>
<function-class>com.example.util.Functions</function-class>
<function-signature>Object[] createArray(int)</function-signature>
</function>
</facelet-taglib>
Run Code Online (Sandbox Code Playgroud)
并按如下方式使用
xmlns:util="http://example.com/util/functions"
...
<ui:repeat value="#{util:createArray(10)}">
<div>content</div>
</ui:repeat>
Run Code Online (Sandbox Code Playgroud)
更新:我刚刚发布了一个增强请求,用于添加begin和end属性<ui:repeat>:http://java.net/jira/browse/JAVASERVERFACES-2240
更新2:我已经根据https://java.net/jira/browse/JAVASERVERFACES_SPEC_PUBLIC-1102亲自为JSF 2.3实现了它.因为Mojarra 2.3-m06你必须能够使用
<ui:repeat begin="1" end="10">
<div>content</div>
</ui:repeat>
Run Code Online (Sandbox Code Playgroud)
Kon*_*kov 15
由于它需要一个集合,你可以在一个支持bean中创建一个集合(包含你想要输出div的时间数量):
public class MyBean {
private List list = new ArrayList<Integer();
{ ... populate the list with numbers, for example ... }
public List getList() {
return list;
}
...
}
Run Code Online (Sandbox Code Playgroud)
然后:
<ui:repeat value="#{myBean.list}" var="item">
<div>content</div>
</ui:repeat>
Run Code Online (Sandbox Code Playgroud)
..它将输出与list属性大小一样多的div .
| 归档时间: |
|
| 查看次数: |
46507 次 |
| 最近记录: |