我开发了一个带有 primefaces 树组件的导航菜单。树节点内部有一个 Project 对象作为数据。我希望能够加载一个带有项目详细信息的视图,当我单击每个项目时,这些详细信息会动态加载。
为此,我在树上定义了一个 ajax 事件选择:
<h:form>
<p:tree value="#{treeBean.root}" var="node"
selection="#{treeBean.selectedNode}" id="tree" >
<p:ajax event="select" listener="#treeBean.onNodeSelect}"/>
<p:treeNode styleClass="treeNode">
<h:outputText value="#{node}" />
</p:treeNode>
</p:tree>
</h:form>
在 treeManagedBean 中调用 onNodeSelectMethod:
@ViewScoped
@Component("treeBean")
@ManagedBean
public class TreeManagedBean{
private Project selectedProject;
public Project getSelectedProject(){
return selectedProject;
}
public void setSelectedProject(Project project){
this.selectedProject = project;
}
public void onNodeSelect(NodeSelectEvent event) {
this.selectedProject = (Project)event.getTreeNode().getData();
FacesContext context = FacesContext.getCurrentInstance();
ConfigurableNavigationHandler handler = (ConfigurableNavigationHandler) context.getApplication().getNavigationHandler();
handler.performNavigation("viewProject");
}
然后我通过 faces-config.xml 加载 viewProject.xhtml,并在另一个 managedBean 中填充属性:
@Component("projectView")
@ViewScoped
@ManagedBean
public class ProjectView {
@ManagedProperty("#{treeBean.selectedProject}")
private Project project;
}
视图加载没有任何错误,但该属性从未设置。ajax 调用有效并且正在第一个 bean 中设置属性。这是这样做的方法吗?