2013-05-14 69 views
0

我有這樣的:在primefaces添加和刪除節點treetable中

<p:treeTable id="#{treeTableId}" value="#{tableBeanRoot}" var="element" 
    resizableColumns="true" 
    selection="#{budgetTemplateElementBean.selectedNode}" 
    selectionMode="single" widgetVar="#{treeTableId}widget"> 

    <f:facet name="header"> 

    </f:facet> 

    <p:column style="width:150px"> 
      ..... 
    </p:column> 
      ..... 
    <f:facet name="footer"> 
     <p:commandButton value="#{msg.addChildNode}" 
      actionListener="#{actionBean.addChildNodeAction}" 
      process="@this,#{treeTableId}" update="#{treeTableId} :growl" /> 
     <p:commandButton value="#{msg.deleteNode}" 
      actionListener="#{actionBean.deleteNodeAction}" 
      process="@this,#{treeTableId}" update="#{treeTableId} :growl" /> 
    </f:facet> 
</p:treeTable> 

在Primefaces treetable中如何添加和刪除樹節點?我可以把什麼東西放回到豆子裏?

感謝

回答

7

添加刪除節點的一​​種解決方案可以是這樣的:

public boolean removeElemetOfTreeNode(TreeNode rootNode, 
     TreeNode nodeToDelete) { 
    if (rootNode.getChildren().remove(nodeToDelete)) { 
     return true; 
    } else { 
     for (TreeNode childNode : rootNode.getChildren()) { 
      if (childNode.getChildCount() > 0) { 
       return removeElemetOfTreeNode(childNode, nodeToDelete); 
      } 

     } 
     return false; 
    } 
} 

public void addNodeAction(ActionEvent event) { 
    if (selectedNode == null) { 
     // TODO: añadir excepcion no seleccionado 
    } 
    Random randomGenerator = new Random(); 
    TreeNode pepe = new DefaultTreeNode(new Configuration("new node" 
      + randomGenerator.nextInt(100), false, "new node" 
      + randomGenerator.nextInt(100), false), 
      selectedNode.getParent()); 
    return; 
} 

public void addChildNodeAction(ActionEvent event) { 
    if (selectedNode == null) { 
     // TODO: añadir excepcion no seleccionado 
    } 
    Random randomGenerator = new Random(); 
    TreeNode pepe = new DefaultTreeNode(new Configuration("new node" 
      + randomGenerator.nextInt(100), false, "new node" 
      + randomGenerator.nextInt(100), false), selectedNode); 
    return; 
} 
+0

謝謝,讓我們試試 – Luermo 2013-05-14 13:51:01

1

我覺得沒有必要刪除節點本身知道節點時BFS遍歷樹的父:

public void removeElemetOfTreeNode(TreeNode nodeToDelete) { 
    TreeNode parent = nodeToDelete.getParent(); 
    if(parent == null){ 
     // throw exception or handle case of root node differently 
    } 
    parent.getChildren().remove(nodeToDelete); 
} 

如果您需要檢查是否nodeToDeleterootNode的後代,也莫重新從nodeToDelete開始,直到達到根,然後將其與rootNode進行比較,而不是使用BFS遍歷整個樹。