`
hanwn123
  • 浏览: 24300 次
  • 性别: Icon_minigender_2
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

rich:tree 来创建动态树问题总结一

阅读更多

  做了七天的动态树,虽然还没有做完但先把一些比较重要的东西记下来。

  目前实现了点击节点动态加载树的功能,但点击左侧的箭头相应的事件还没有找到,还是希望有经验的朋友可以指点一二。

  <h:panelGrid columns="2" width="100%" columnClasses="col1,col2">
  <rich:tree style="width:300px" nodeSelectListener="#{tree1bean.nodeload}" toggleOnClick="true"  switchType="ajax" value="#{tree1bean.treeNode}">
  </rich:tree>
  </h:panelGrid>

 

以上的toggleOnClick实现了点击节点时展开、关闭树节点。

         switchType="ajax"实现了局部刷新,只是树加载的部分刷新,但不重载整个页面。

 

package org.jboss.test.main;

import java.util.List;

import javax.ejb.Remove;
import javax.faces.event.AbortProcessingException;
import javax.persistence.EntityManager;

import org.jboss.seam.ScopeType;
import org.jboss.seam.annotations.In;
import org.jboss.seam.annotations.Name;
import org.jboss.seam.annotations.Scope;
import org.richfaces.component.UITree;
import org.richfaces.event.NodeExpandedEvent;
import org.richfaces.event.NodeSelectedEvent;
import org.richfaces.model.TreeNode;
import org.richfaces.model.TreeNodeImpl;

@Scope(ScopeType.SESSION)
@Name("tree1bean")
public class Tree1Bean{
 private Tree tree;
 private TreeNode treenode = null;
 private List<Tree> onloadtree;
 private List<Tree> onloadtree1;
 private String selectnodesql = "from Tree t where t.parentid = ? order by t.id";
 private int linkid;
 private int flg;
 private int parentid;

 @In("entityManager")
 private EntityManager em; 

 private void firstNode(int id,TreeNode node){
        onloadtree = em.createQuery(selectnodesql).setParameter(1, id).getResultList();
        for (int i=0;i<onloadtree.size();i++){
         TreeNodeImpl nodeImpl = new TreeNodeImpl();
         nodeImpl.setData(onloadtree.get(i).getName());
         node.addChild(new Integer(onloadtree.get(i).getId()), nodeImpl);
         secondeNode(onloadtree.get(i).getId(),nodeImpl);
       }
 }
 
    private void secondeNode(int id,TreeNode node){
        onloadtree1 = em.createQuery(selectnodesql).setParameter(1, id).getResultList();
        for (int i=0;i<onloadtree1.size();i++){
         TreeNodeImpl nodeImpl = new TreeNodeImpl();
         nodeImpl.setData(onloadtree1.get(i).getName());
         node.addChild(new Integer(onloadtree1.get(i).getId()), nodeImpl);
       }
    }
 
 public TreeNode getTreeNode(){
  if (treenode == null){
   treenode = new TreeNodeImpl();
   parentid = 0;
   firstNode(parentid,treenode);
  }
  return treenode;
 }
 
 public void nodeload(NodeSelectedEvent event){
  UITree tree = (UITree) event.getComponent();
  String  sss [] = tree.getRowKey().toString().split(":");
  linkid = Integer.parseInt(sss[sss.length-1]);
  System.out.println("linkid="+linkid);
  tree.clearTreeNodeState();
  firstNode(linkid,tree.getModelTreeNode());
 }

 public int getLinkid() {
  return linkid;
 }
 
 public void setLinkid1(int linkid) {
  this.linkid = linkid;
 }
  
 @Remove
 public void destroy() {
  // TODO Auto-generated method stub
  
 }
}

以上的tree.clearTreeNodeState();实现了收缩节点以后其以后的节点都收缩了回去。回到了初始状态

 

 

分享到:
评论
3 楼 ty408968356 2009-09-30  
你没有找到的那个事件好像是rich:tree的changeExpandListener属性,在后台bean中生命一个方法,如:public void processExpansion(NodeExpandedEvent e){},希望对你有帮助
2 楼 bank_river 2009-06-30  
我也在学习中,代码能发一个吗?bank_river@yeah.net
多谢!
1 楼 cuixiufang 2009-05-26  
  有价值!!

相关推荐

    richfaces参考文档

    - **&lt;rich:tree&gt;**:创建可扩展的树形视图,支持拖放操作和节点状态管理。 - **&lt;rich:dragDropTree&gt;**:增强版的树组件,支持拖放操作,常用于构建可配置的树状结构。 ### RichFaces 集成与配置 - **Maven 依赖**...

    swing界面设计之JTree

    - **代码实例:构建一棵树**:通过具体代码示例展示了如何创建一个简单的树结构。 - **相关语句解释**:对代码中的关键部分进行了注释和解释。 #### (十六) JTree应用示例——文件路径 **AnimatedIconTreeExample....

    java树形导航的实现

    首先,树形导航的实现通常基于`TreeViewer`类,它是Eclipse RCP(Rich Client Platform)提供的一个视图组件,能够展示层次结构数据。在代码中,我们看到了`TreeViewer`的引用,如`TreeSelection`、`TreePath`等,...

    silverlight4.0 Treeview 从 wcf 动态获取数据

    在本例中,我们将创建一个WCF服务来提供动态数据。在VS2010中,选择“添加新项目”,然后选择“WCF Service Library”模板。在服务接口中定义方法,以返回树形数据结构,例如一个包含节点和子节点的对象集合。 ```...

    EXTJS开发总结.pdf

    ExtJS 是一种强大的 Rich Internet Application (RIA) 框架,专注于客户端的复杂用户界面开发。与 Prototype 和 jQuery 等轻量级库不同,ExtJS 提供了一个完整的组件模型和丰富的用户界面控件,更适合构建功能丰富的...

    dwz 学习文档

    **DWZ富客户端框架**是一款由中国人自主开发的、基于jQuery的Ajax RIA(Rich Internet Applications)开源框架。该框架的设计初衷在于提供一种简单实用、易于扩展且能快速构建RIA应用的方法。 #### 设计理念与优势 ...

    rap总结

    "rcp 视图中的菜单--树形 - a13151055695@126的日志 - 网易博客.mht"可能包含有关RCP(Rich Client Platform)的信息,RCP是Eclipse平台的一部分,用于构建桌面应用程序。博主可能讲解了如何在RCP应用中创建和管理树...

    Ext2.0一些小例子

    总结来说,Ext2.0是一个功能强大的前端开发框架,通过一系列精心设计的组件和数据绑定机制,可以构建出功能强大、交互性良好的Web应用。通过学习并实践这些小例子,开发者可以逐步掌握Ext2.0的精髓,从而提高开发...

    一个树状菜单

    总结来说,"一个树状菜单"涉及了前端开发中的HTML、CSS、JavaScript基础,以及数据结构、算法、框架组件、响应式设计和无障碍性等多个方面。通过深入理解和实践这些知识点,开发者可以构建出美观且易用的树状菜单。

    利用Dojo和JSON建立无限级AJAX动态加载的功能模块树

    Dojo是一个开源的JavaScript框架,它提供了一套强大的工具集用于创建高度交互性的RIA(Rich Internet Applications)。Dojo的优势在于: 1. **高性能**:Dojo框架内部实现了高效的DOM操作和事件处理机制。 2. **跨...

    DWZ使用帮助文档

    - **Tree扩展**: 创建树形结构的数据展示。 - **Panel扩展**: 构建可拖动、可折叠的面板。 - **日历控件**: 添加日期选择器功能。 - **url变量替换**: 自动替换URL中的变量。 - **checkbox全选/反选**: 控制复选框的...

    Ext 3.0中文手册及帮助文档

    Ext 3.0是Sencha公司开发的一个JavaScript框架,主要用于构建富互联网应用程序(Rich Internet Applications,简称RIA)。这个中文手册及帮助文档包含了Ext 3.0的全面介绍、API参考、示例代码以及常见问题解答,是...

    extjs3.0+struts2源码

    ExtJS 是一个用于构建富客户端(Rich Internet Applications,RIA)的JavaScript库,它提供了丰富的组件库和用户界面,使得开发者可以创建出具有桌面应用程序般用户体验的Web应用。Struts2 则是基于MVC(Model-View-...

    Extjs基础教程

    6. **树**(Tree):用于展示分层次的数据结构。 7. **表单**(Form):包含多个控件用于收集用户输入信息。 #### 五、总结 Extjs 作为一种强大的前端框架,不仅提供了丰富的 UI 组件,还支持 MVC 架构模式,有助...

    Flex,IBM组织结构图例子

    在Flex中,这些可以通过自定义组件实现,例如,使用Tree或HierarchicalData类来构建树形结构,每个节点代表一个职位或部门,通过数据绑定将数据模型与视图关联起来。此外,图形化呈现可能利用了Graph或Canvas组件,...

    SWT API 帮助文档 及源码

    1. **控件(Widgets)**:SWT 提供了各种原生控件,如按钮(Button)、文本框(Text)、列表(List)、表格(Table)、树(Tree)等。这些控件直接映射到操作系统底层的控件,因此在不同平台上表现一致。 2. **事件...

Global site tag (gtag.js) - Google Analytics