我正在尝试使用名为的 Primefaces JSF 组件contentFlow
,此处演示:http: //www.primefaces.org/showcase/ui/multimedia/contentFlow.xhtml
我在支持 bean 中添加了两个图像。它们都可以在不使用的情况下显示contentFlow
,因此它们可用且位于正确的位置。问题是,contentFlow
仅显示当前选择的图像。预期的行为是,它也显示所有其他图像。
我搜索了很多,还找到了 Primefaces 组件的文档来验证我的 XHTML。我还更改了 JSF 日志级别以查看所有调试消息,但 JSF 一直告诉我一切都很好。
除了项目的配置,我没有做任何比展示柜说的更多的事情。这是我的设置的摘要:
- 我在 Windows x64 上使用 Apache Tomcat 8.0.39
- Firefox 50.0.2 和 Chrome 版本 55.0.2883.75 m(64 位)显示相同的结果(仅当前选择的图像可见)
- 我正在使用 Java 8
这些是项目的依赖项
<dependency> <groupId>org.primefaces</groupId> <artifactId>primefaces</artifactId> <version>6.0.RC4</version> </dependency> <dependency> <groupId>com.sun.faces</groupId> <artifactId>jsf-api</artifactId> <version>2.2.14</version> </dependency> <dependency> <groupId>com.sun.faces</groupId> <artifactId>jsf-impl</artifactId> <version>2.2.14</version> </dependency> <dependency> <groupId>javax.servlet</groupId> <artifactId>servlet-api</artifactId> <version>2.5</version> <scope>provided</scope> </dependency>
这是我的支持 bean:
package de.schuettec.jsfquestion.contentFlow;
import java.util.ArrayList;
import java.util.List;
import javax.annotation.PostConstruct;
import javax.faces.bean.ManagedBean;
@ManagedBean
public class Images {
private List<String> images;
@PostConstruct
public void init() {
images = new ArrayList<String>();
images.add("img-01.png");
images.add("img-02.png");
}
public List<String> getImages() {
return images;
}
}
这是我的 XHTML 页面:
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:p="http://primefaces.org/ui">
<h:head>
</h:head>
<h:body>
<h:form>
<p:contentFlow value="#{images.images}" var="image">
<p:graphicImage name="/images/#{image}" styleClass="content" />
<div class="caption">#{image}</div>
</p:contentFlow>
</h:form>
</h:body>
</html>
我创建了一个最小的复制示例,可通过此处的 GitHub https://github.com/schuettec/jsf-question获得。这是一个重现此问题的完整 Maven 项目。
如果 JSF/Primefaces 专家中的某个人可以看看这个问题,我将不胜感激。我喜欢 JSF 和 Primefaces 组件,并且真的很想了解这里出了什么问题。
先感谢您!