1

我开发了一个带有 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 中设置属性。这是这样做的方法吗?

4

1 回答 1

0

我解决了它只是向 managedBeans 添加了一个标识符,因为我有义务提供一个默认构造函数:

@ViewScoped
@Component("treeBean")
@ManagedBean("treeBean")
public class TreeManagedBean{ 
   public TreeManagedBean(){}
}

@Component("projectView")
@ViewScoped
@ManagedBean("projectView")
public class ProjectView {
    @ManagedProperty("#{treeBean.selectedProject}")
    private Project project; 
    public ProjectView(){}
}
于 2012-10-01T09:25:58.637 回答