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

相关文章
|
6月前
|
缓存 前端开发
easyui02(tree前端工作)
easyui02(tree前端工作)
|
2月前
|
前端开发 JavaScript 开发者
深入理解前端性能优化中的Webpack Tree Shaking
【2月更文挑战第2天】在前端开发中,性能优化一直是开发者们不断追求的目标之一。而在这个过程中,Webpack Tree Shaking 技术作为一种重要的优化手段,对于减小前端应用的体积、提高加载速度起到了至关重要的作用。本文将深入探讨Webpack Tree Shaking 技术的原理和实现方式,帮助读者更好地理解并运用这一技术来优化前端应用性能。
webpack进阶篇(二十一):Tree Shaking的使用和原理分析
webpack进阶篇(二十一):Tree Shaking的使用和原理分析
163 0
webpack进阶篇(二十一):Tree Shaking的使用和原理分析
|
前端开发
前端项目实战17-自定义tree
前端项目实战17-自定义tree
72 0
|
前端开发
Bootstrap Tree View,简单而优雅的树结构组件(2)
Bootstrap Tree View,简单而优雅的树结构组件
278 0
Bootstrap Tree View,简单而优雅的树结构组件(2)
|
JSON 前端开发 JavaScript
Bootstrap Tree View,简单而优雅的树结构组件(1)
Bootstrap Tree View,简单而优雅的树结构组件
493 0
Bootstrap Tree View,简单而优雅的树结构组件(1)
|
Web App开发 JavaScript 前端开发
10 个最佳的 Node.js 的 MVC 框架
Node.js 是一个基于Chrome JavaScript 运行时建立的一个平台, 用来方便地搭建快速的, 易于扩展的网络应用· Node.js 借助事件驱动, 非阻塞 I/O 模型变得轻量和高效, 非常适合 run across distributed devices 的 data-intensive 的实时应用·
378 0
10 个最佳的 Node.js 的 MVC 框架
|
前端开发 JavaScript 索引

热门文章

最新文章