用dTree组件生成无限级导航树
首先是下载dTree组件,本文附件中提供完整的示例,直接使用即可。下面我们先来看看dTree组件的结构:
这很简单,由一个JS文件,一个样式表文件和提供的基本图标构成,总体20几K,非常小,不占用网络流量。制作dTree的导航树时,也是一个HTML页面,那么我们就要在页面引入相关资源:
- <head>
- <title>导航树</title>
- <meta http-equiv="Content-Type" content="text/html; charset=utf8" />
- <style type="text/css">@import url('components/dtree/dtree.css');</style>
- <script type="text/javascript">var dtreeIconBasePath = "components/dtree";</script>
- <script language="javascript" src="components/dtree/dtree.js"></script>
- </head>
下面就是导航树内容的编写了,做一个很简单很强大的示例:
- <script type="text/javascript">
- var treeMenu = [
- { level:1, name:"用户管理"},
- { level:2, name:"用户列表", ico:"images/tico_way.gif",link:"user_list.html"},
- { level:2, name:"角色管理"},
- { level:3, name:"角色列表", ico:"images/tico_way.gif",link:"role_list.html"},
- { level:3, name:"用户角色", ico:"images/tico_way.gif",link:"ur_list.html"},
- { level:1, name:"信息管理"},
- { level:2, name:"新闻管理", ico:"images/tico_way.gif",link:"news_list.html"},
- { level:2, name:"公告管理", ico:"images/tico_way.gif",link:"bulletin_list.html"},
- { level:1, name:"系统邮件", ico:"images/tico_way.gif"},
- { level:1, name:"网络文件", ico:"images/tico_way.gif",link:"disk_list.html"}
- ];
- </script>
可以看出level是当前项目的层级,name就是显示的名称,ico是指定的图标,不指定时系统使用默认图标,link就是点击时进入的地址。当然非叶子节点元素一般是不需要地址的,那么不写就可以了,而叶子节点不写的话该行就是不可点击进入的效果。这是一个混合了1,2,3层的导航树。有了这些还不够,它们不能被解析,下面来看看解析的JS。
- <script type="text/javascript">
- //建立新树
- tree = new dTree('tree');
- tree.config.target = "MainFrame";
- tree.config.useCookies = false;
- var selNum = -1;
- var link = "";
- //根目录
- tree.add(0,-1,'系统管理中心', null, null, null, '', '');
- var count = 0;
- var pLevelIdArray = new Array();
- pLevelIdArray[1] = 0;
- var currLevel = 1;
- for (var i=0; i<treeMenu.length; i++) {
- var item = treeMenu[i];
- var itemLevel = item.level;
- pLevelIdArray[itemLevel+1] = ++count;
- if (item.link!=null && item.link!="") {
- if (item.ico!=null) {
- tree.add(count, pLevelIdArray[itemLevel], item.name, item.link, null, null, item.ico, item.ico);
- } else {
- tree.add(count, pLevelIdArray[itemLevel], item.name, item.link);
- }
- } else {
- if (item.ico!=null) {
- tree.add(count, pLevelIdArray[itemLevel], item.name, null, null, null, item.ico, item.ico);
- } else {
- tree.add(count, pLevelIdArray[itemLevel], item.name);
- }
- }
- if (item.select) {
- selNum = count;
- link = item.link;
- }
- }
- document.write(tree);
- tree.openAll();
- if (selNum != -1) {
- tree.openTo(selNum,true);
- top.document.frames["MainFrame"].location.href=link;
- }
- </script>
这样就可以了,主要是这里用了frame,页面的显示会在MainFrrame中显示,这是一般管理系统的结构,左侧导航树,右侧主显示区域,上侧是登录信息和模块切换,下侧就是版权声明了。
这样就能正常显示一棵树了,但是有时我们需要折叠和展开导航树,这个也很简单,如下即可:
- <div style="display:block;margin-bottom:5px;">
- 菜单控制:
- 【<a href="#" onclick="tree.openAll();this.blur();return false;" style="color:#333333">展开</a>】
- 【<a href="#" onclick="tree.closeAll();this.blur();return false;" style="color:#333333">折叠</a>】
- </div>
这样就完整了,我们来看看实际的效果吧:
折叠后的效果就是:
实际中,页面代码不需要每个页面都完整写出,我们可以抽取成宏,直接调用宏即可,下面结合FreeMarker来优化一下编码结构,实际生成的效果都是一样的。
- <#-- 树形控件 tree -->
- <#macro tree root="" display="">
- <style type="text/css">@import url('components/dtree/dtree.css');</style>
- <script type="text/javascript">var dtreeIconBasePath = "components/dtree";</script>
- <script language="javascript" src="${base}/components/dtree/dtree.js"></script>
- <#nested>
- <div style="display:${display};margin-bottom:5px;">菜单控制:【<a href="javascript:void(0)" onclick="tree.openAll();this.blur();return false;" style="color:#333333">展开</a>】【<a href="javascript:void(0)" onclick="tree.closeAll();this.blur();return false;" style="color:#333333">折叠</a>】</div>
- <div class="dtree">
- <script type="text/javascript">
- //建立新树
- tree = new dTree('tree');
- tree.config.target = "MainFrame";
- tree.config.useCookies = false;
- var selNum = -1;
- var link = "";
- //根目录
- tree.add(0,-1,'${root}', null, null, null, '${base}/images/tico_root.gif', '${base}/images/tico_root.gif');
- var count = 0;
- var pLevelIdArray = new Array();
- pLevelIdArray[1] = 0;
- var currLevel = 1;
- for (var i=0; i<treeMenu.length; i++) {
- var item = treeMenu[i];
- var itemitemLevel = item.level;
- pLevelIdArray[itemLevel+1] = ++count;
- if (item.link!=null && item.link!="") {
- if (item.ico!=null) {
- tree.add(count, pLevelIdArray[itemLevel], item.name, item.link, null, null, item.ico, item.ico);
- } else {
- tree.add(count, pLevelIdArray[itemLevel], item.name, item.link);
- }
- } else {
- if (item.ico!=null) {
- tree.add(count, pLevelIdArray[itemLevel], item.name, null, null, null, item.ico, item.ico);
- } else {
- tree.add(count, pLevelIdArray[itemLevel], item.name);
- }
- }
- if (item.select) {
- selNum = count;
- link = item.link;
- }
- }
- document.write(tree);
- tree.openAll();
- if (selNum != -1) {
- tree.openTo(selNum,true);
- top.document.frames["MainFrame"].location.href=link;
- }
- </script>
- </div>
- </#macro>
这是FreeMarker的宏定义。那么在页面如何使用呢,很简单:
- <@p.tree root="管理中心" display="block">
- <script type="text/javascript">
- var treeMenu = [
- { level:1, name:"用户管理"},
- { level:2, name:"用户列表", ico:"images/tico_way.gif",
- link:"user_list.html"},
- { level:2, name:"角色管理"},
- { level:3, name:"角色列表", ico:"images/tico_way.gif",
- link:"role_list.html"},
- { level:3, name:"用户角色", ico:"images/tico_way.gif",
- link:"ur_list.html"},
- { level:1, name:"信息管理"},
- { level:2, name:"新闻管理", ico:"images/tico_way.gif",
- link:"news_list.html"},
- { level:2, name:"公告管理", ico:"images/tico_way.gif",
- link:"bulletin_list.html"},
- { level:1, name:"系统邮件", ico:"images/tico_way.gif"},
- { level:1, name:"网络文件", ico:"images/tico_way.gif",
- link:"disk_list.html"}
- ];
- </script>
- </@p.tree>
后续我们会结合RBAC模型来介绍一下简单动态权限树的生成。一家之言,仅供参考,希望对使用者有用。
- dTreeDemo.rar (13.5 KB)
- 下载次数: 299
用dTree组件生成无限级导航树的更多相关文章
- JavaScript导航树
JS导航树 整理之前的小代码片段,放到博客,便于以后完善查看: 该JS导航树实际效果,[GSP+社区网站专题课程页面导航树]地址:http://gsp.inspur.com/knowledge/zhu ...
- Vue视图渲染原理解析,从构建VNode到生成真实节点树
前言 在 Vue 核心中除了响应式原理外,视图渲染也是重中之重.我们都知道每次更新数据,都会走视图渲染的逻辑,而这当中牵扯的逻辑也是十分繁琐. 本文主要解析的是初始化视图渲染流程,你将会了解到从挂载组 ...
- SAP CRM 将组件整合至导航栏中
到现在,我们已经可以让组件独立地显示.我们只是运行它.让它显示在Web UI中.让我们把组件整合进导航栏,使我们可以在正常登录Web UI时访问它. 步骤一: 为你的UI组件主窗体创建一个内向插件. ...
- [WebKit内核] JavaScript引擎深度解析--基础篇(一)字节码生成及语法树的构建详情分析
[WebKit内核] JavaScript引擎深度解析--基础篇(一)字节码生成及语法树的构建详情分析 标签: webkit内核JavaScriptCore 2015-03-26 23:26 2285 ...
- 使用Python从Markdown文档中自动生成标题导航
概述 知识与思路 代码实现 概述 Markdown 很适合于技术写作,因为技术写作并不需要花哨的排版和内容, 只要内容生动而严谨,文笔朴实而优美. 为了编写对读者更友好的文章,有必要生成文章的标题导航 ...
- 隐藏左侧快速导航除DMS导航树之外的其他区域
<style type="text/css"> /*隐藏左侧快速导航除DMS导航树之外的其他区域*/ .ms-quicklaunchouter { display: n ...
- JXL组件生成报告错误(两)
JXL组件生成报告 1.详细报错例如以下: usage: java org.apache.catalina.startup.Catalina [ -config {pathname} ] [ -non ...
- Bootstrap入门(十三)组件7:导航条
Bootstrap入门(十三)组件7:导航条 1.默认样式的导航条 2.嵌入表单和按钮 3.嵌入文本和非导航的链接 4.组件排列和下拉菜单 5.固定在顶部/底部 6.反色的导航条 7.路径导航 首先先 ...
- Bootstrap入门(十二)组件6:导航标签页
Bootstrap入门(十二)组件6:导航标签页 1.标签页 2.胶囊式标签页 3.垂直展示 4.两端对齐的标签页 5.禁用的链接 6.添加下拉菜单 先引入本地的CSS文件和JS文件(注:1. ...
随机推荐
- Javascript 文件操作(整理版)
Javascript 文件操作 一.功能实现核心:FileSystemObject 对象 其实,要在Javascript中实现文件操作功能,主要就是依靠FileSystemobject对象.在详细介绍 ...
- Android Support库百分比布局
之前写过一篇屏幕适配的文章Android 屏幕适配最佳实践,里面提到了类似百分比布局的东西,可是该方法缺点非常明显,就会添加非常多没用的数据,导致apk包变大. 而谷歌的support库中,添加了一个 ...
- 原生 javascript 学习之 js变量
1.变量的命名 方法的命名(驼峰命名法) 全部小写 : 单词与单词之间全部下划线 (my_namespace) 大小写混合 : 第一个单词首字母小写其他单词首字母大写. 规则 首字符 英文字母或下划线 ...
- eclipse 404以及tomcat failed to start错误
eclipse中的servlet项目有时会不编译,不编译可能就会出现404错误,因为在build path的输出目录并没有class文件,然而如果在输出目录引入之前编译的class文件,就可能出现cl ...
- 网站全局js代码
这几天开始看公司的一套系统,整理的网站全局js代码 /*文件名:base.js功能说明:全站通用的全局变量及公用方法创建日期:2010-09-26*///引入jquery库文件document.wri ...
- (转) .NET实现Repeater控件+AspNetPager控件分页
SqlConnection (.NET C#) 连接及分页 .net的访问数据机制决定了访问大量数据时会致使客户端机器消耗大量资源,因此有必要对数据进行分页显示,开发工具vs.net+sqlserve ...
- 软件工程师所需掌握的“终极技术”是什么?
软件工程师所需掌握的"终极技术"是什么? http://yunli.blog.51cto.com/831344/1019990 最近,我在微博上看到@程序员邹欣老师发的一条微博 - ...
- .net mvc结合微软提供的FormsAuthenticationTicket登陆
一.Web.config <system.web> <compilation debug="true" targetFramework="4.5&quo ...
- debian系统下安装ssh服务
它是什么?? SSH 为 Secure Shell 的缩写,简单地说,SSH 为建立在应用层基础上的安全协议.SSH 是目前较可靠,专为远程登录会话和其他网络服务提供安全性的协议.利用 SSH 协议可 ...
- Android 代码编辑器中实现代码语法高亮
想写一款Android手机上的代码编辑器,实现类似c4droid中代码语法高亮 通过Android中的控件WebView中嵌入html网页,html引入CodeMirror这个第三方库就可以了,其实就 ...