JSF Tree学习...

简介:
RAD7.0开发Faces Portlet.使用到Tree组件.
=====================================

使用JSF中的<ig:Sidebar></ig:Sidebar>实现动态加载菜单,其中bar.getChildren().add(aSidebarGroup);是实现动态加载首节点,HtmlSidebarGroup aSidebarGroup = (HtmlSidebarGroup) application.createComponent(HtmlSidebarGroup.COMPONENT_TYPE);
    aSidebarGroup.setText(boardName);
    aSidebarGroup.setExpanded(true);
    aSidebarGroup.setId(viewRoot.createUniqueId());实现加载该节点下的子节点,非常方便。

private Sidebar buildSideBar(Sidebar bar)
 {
  boolean isInitialised = bar.getAttributes().get("IS_INITIALISED")!=null;
  
  if (!isInitialised) {
   // Get a reference to the JSF Application, 
   // we need it to create value bindings later-on
   Application application = FacesContext.getCurrentInstance().getApplication();
   UIViewRoot viewRoot = FacesContext.getCurrentInstance().getViewRoot();
   
   /* Create Infragistics SidebarGroup */
   // Set the Sidebar's width and height
   bar.getAttributes().put("style","width: 155px; height: 590px;");
   // Create SidebarGroup
   List list = this.getBoardNameForMenu();
   for(int i = 0 ;i<list.size();i++)
   {
    Object[] row = (Object[])list.get(i);
   //Object[] row = (Object[])list.listIterator().next();
    String boardId = String.valueOf(row[0]);
    String boardName = String.valueOf(row[1]);
    String parentId = String.valueOf(row[2]);
    HtmlSidebarGroup aSidebarGroup = (HtmlSidebarGroup) application.createComponent(HtmlSidebarGroup.COMPONENT_TYPE);
    aSidebarGroup.setText(boardName);
    aSidebarGroup.setExpanded(true);
    aSidebarGroup.setId(viewRoot.createUniqueId());
   
    // Add the newly created SidebarGroup to the Sidebar's children list
    bar.getChildren().add(aSidebarGroup);
    
    List ls = this.getBoardNameForMenuBar(Integer.parseInt(boardId));
    if(ls.size() != 0)
    {
     for(int j=0;j<ls.size();j++)
     {
      Object[] row1 = (Object[])ls.get(j);
      String boardid = String.valueOf(row1[0]);
      String boardname = String.valueOf(row1[1]);
      //HtmlSidebarGroup aSidebarGroup = (HtmlSidebarGroup) application.createComponent(HtmlSidebarGroup.COMPONENT_TYPE);
      HtmlLink aLink1 = (HtmlLink)application.createComponent(HtmlLink.COMPONENT_TYPE);
      aLink1.setId(viewRoot.createUniqueId());
      //aSidebarGroup.setText(sidebarGroupNameStr);
      //aSidebarGroup.setExpanded(true);
      //aSidebarGroup.setId(viewRoot.createUniqueId());
      //aLink1.setId(parentId);
      aLink1.setUrl("/pages/bbs/visitor/topic/topicforboard.jsf?boardid="+boardid+"");
      aLink1.setValue(boardname);
      aSidebarGroup.getChildren().add(aLink1);
     }
    }
    
   }

本文转自kenty博客园博客,原文链接http://www.cnblogs.com/kentyshang/archive/2008/06/04/1213825.html如需转载请自行联系原作者


kenty

相关文章
|
缓存 前端开发
easyui02(tree前端工作)
easyui02(tree前端工作)
|
Java 应用服务中间件 API
Flowable UI Web应用搭建教程(图解)
Flowable UI Web应用搭建教程(图解)
540 0
|
2月前
|
Web App开发 JavaScript 前端开发
构建高效Web应用:Node.js与Express框架的深度整合
【9月更文挑战第28天】在现代Web开发领域,Node.js和Express框架的结合已成为打造高性能、易扩展应用的黄金组合。本文将深入探讨如何利用这一技术栈优化Web应用架构,提供具体实践指导,并分析其性能提升的内在机制。通过代码示例,我们将展示从基础搭建到高级功能的实现过程,旨在为开发者提供一条清晰的学习路径,以实现技术升级和项目效率的双重提升。
47 3
|
6月前
|
前端开发 JavaScript 开发者
深入理解前端性能优化中的Webpack Tree Shaking
【2月更文挑战第2天】在前端开发中,性能优化一直是开发者们不断追求的目标之一。而在这个过程中,Webpack Tree Shaking 技术作为一种重要的优化手段,对于减小前端应用的体积、提高加载速度起到了至关重要的作用。本文将深入探讨Webpack Tree Shaking 技术的原理和实现方式,帮助读者更好地理解并运用这一技术来优化前端应用性能。
|
JavaScript 前端开发
Webpack5 系列(五):Tree Shaking
Webpack5 系列(五):Tree Shaking
265 1
webpack进阶篇(二十一):Tree Shaking的使用和原理分析
webpack进阶篇(二十一):Tree Shaking的使用和原理分析
258 0
webpack进阶篇(二十一):Tree Shaking的使用和原理分析
webpack原理篇(六十三):插件基本结构介绍
webpack原理篇(六十三):插件基本结构介绍
99 0
webpack原理篇(六十三):插件基本结构介绍
webpack进阶篇(二十二):Scope Hoisting使用和原理分析
webpack进阶篇(二十二):Scope Hoisting使用和原理分析
89 0
webpack进阶篇(二十二):Scope Hoisting使用和原理分析
|
前端开发 JavaScript
Backbone.js:为复杂WEB应用程序提供MVC结构
Backbone.js:为复杂WEB应用程序提供MVC结构
|
缓存 JSON JavaScript
图解Webpack——实现一个Loader
图解Webpack——实现一个Loader
图解Webpack——实现一个Loader