利用Ext Js生成动态树实例代码


Posted in Javascript onSeptember 08, 2008

一. 需求

要求生成一颗部门树,初始只列出根部门
当点击一个部门节点时,动态载入该部门下的直属子部门,并展开该部门节点
部门节点要求支持右键单击事件,当点击右键时,列出相关操作菜单
二. 关键类

这里主要涉及Ext JS的两个类:

Ext.tree.TreeNode
Ext.menu.Menu
相关API可以参考:http://extjs.com/deploy/ext/docs/

三. 代码示例

1. 先看一下测试页面

<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<title>Reorder TreePanel</title> 
<link rel="stylesheet" type="text/css" href="../../resources/css/ext-all.css" /> 
<script type="text/javascript" src="../../adapter/ext/ext-base.js"></script> 
<script type="text/javascript" src="../../ext-all.js"></script> 
<script type="text/javascript" src="reorder.js"></script> 
<!-- Common Styles for the examples --> 
<link rel="stylesheet" type="text/css" href="../shared/examples.css" /> 
<link rel="stylesheet" type="text/css" href="../shared/lib.css" /> 

<script type="text/javascript"> 
/************** 
onload事件 
***************/ 
window.onload=function(){ 
createTree(3); 
} 
</script> 

</head> 
<body> 
<script type="text/javascript" src="../shared/examples.js"></script> 
<h1>现在要生成一颗动态树</h1> 
<div id="container"> 
</div> 
</body> 
</html>

2. 再看一下生成树的函数
/*********************************** 
创建树 
by chb 
************************************/ 
function createTree(n){ 
Ext.QuickTips.init(); 
var mytree=new Ext.tree.TreePanel({ 
el:"container", 
animate:true, 
title:"Extjs动态树", 
collapsible:true, 
enableDD:true, 
enableDrag:true, 
rootVisible:true, 
autoScroll:true, 
autoHeight:true, 
width:"30%", 
lines:true 
}); 
//根节点 
var root=new Ext.tree.TreeNode({ 
id:"root", 
text:"集团公司", 
expanded:true 
}); 

for(var i=0;i<n;i++){ 
var sub1=new Ext.tree.TreeNode({ 
id:i+1, 
text:"子公司"+(i+1), 
singleClickExpand:true, 
listeners:{ 
//监听单击事件 
"click":function(node){ 
myExpand(node); 
}, 
//监听右键 
"contextmenu":function(node,e){ 
//列出右键菜单 
menu=new Ext.menu.Menu([ 
{ 
text:"打开当前节点", 
icon:"list.gif", 
handler:function(){ 
myExpand(node); 
} 
}, 
{ 
text:"编辑当前节点", 
icon:"list.gif", 
handler:function(){ 
alert(node.id); 
} 
}, 
{ 
text:"删除当前节点", 
icon:"list.gif", 
handler:function(){ 
alert(node.id); 
} 
}]); 
//显示在当前位置 
menu.showAt(e.getPoint()); 
} 
} 
}); 
root.appendChild(sub1); 
} 
mytree.setRootNode(root);//设置根节点 
mytree.render();//不要忘记render()下,不然不显示哦 
}

3. 展开子节点的代码
/****************************************** 
展开节点 
******************************************/ 
function myExpand(node){ 
if(node.id=='1'){ 
if(node.item(0)==undefined){ 
node.appendChild(new Ext.tree.TreeNode({ 
id:node.id+'1', 
text:node.text+"的第一个儿子", 
hrefTarget:"mainFrame", 
listeners:{//监听 
"click":function(node,e){ 
expand2(node) 
} 
} 
})); 
} 
node.expand(); 

}else if(node.id=='2'){ 
node.appendChild(new Ext.tree.TreeNode({ 
id:node.id+'2', 
text:node.text+"的第一个儿子", 
hrefTarget:"mainFrame", 
listeners:{//监听 
"click":function(node){ 
expand2(node) 
} 
} 
})); 
}else{ 
alert(node.id+"没有子部门了"); 
} 
}

读者可以自己运行一下如上代码,会发现如下现象:无论点击“子公司1”多少次,只会列出“子公司1的第一个儿子”一个节点,而每点击一次“子公司2”,就会多出一个“子公司2的第一个儿子”节点,这是为什么呢?

因为每次点击都会激发myExpand函数,而“子公司1”上加了node.item(0)==undefined的判断,这里明白了?
即:如果该部门下没有子部门,则载入子部门,否则只展开,不重新载入。

好了,就到这里吧,困了,就不详细解释了o(∩_∩)o...哈哈

Javascript 相关文章推荐
javascript 日期时间函数(经典+完善+实用)
May 27 Javascript
jQuery中绑定事件的命名空间详解
Apr 05 Javascript
一个挺有意思的Javascript小问题说明
Sep 26 Javascript
Angular Js文件上传之form-data
Aug 28 Javascript
Vue自定义指令介绍(2)
Dec 08 Javascript
JavaScript实现各种排序的代码详解
Aug 28 Javascript
vue项目中使用ueditor的实例讲解
Mar 05 Javascript
Vue-cli配置打包文件本地使用的教程图解
Aug 02 Javascript
详解JavaScript原生封装ajax请求和Jquery中的ajax请求
Feb 14 jQuery
JS实现的tab切换并显示相应内容模块功能示例
Aug 03 Javascript
javascript中的数据类型检测方法详解
Aug 07 Javascript
Javascript组合继承方法代码实例解析
Apr 02 Javascript
用JavaScrpt实现文件夹简单轻松加密的实现方法图文
Sep 08 #Javascript
Javascript条件判断使用小技巧总结
Sep 08 #Javascript
SyntaxHighlighter代码加色使用方法
Sep 07 #Javascript
很多人都是用下面的js刷新站IP和PV
Sep 05 #Javascript
动态修改DOM 里面的 id 属性的弊端分析
Sep 03 #Javascript
IE浏览器PNG图片透明效果代码
Sep 02 #Javascript
JavaScript监测ActiveX控件是否已经安装过的代码
Sep 02 #Javascript
You might like
php图片加水印原理(超简单的实例代码)
2013/01/18 PHP
PHP处理Json字符串解码返回NULL的解决方法
2014/09/01 PHP
smarty实现多级分类的方法
2014/12/05 PHP
Yii支持多域名cors原理的实现
2018/12/05 PHP
thinkphp框架使用JWTtoken的方法详解
2019/10/10 PHP
jquery判断浏览器后退时候弹出消息的方法
2014/08/11 Javascript
JavaScript中使用Object.prototype.toString判断是否为数组
2015/04/01 Javascript
基于jQuery实现复选框是否选中进行答题提示
2015/12/10 Javascript
node.js+express制作网页计算器
2016/01/17 Javascript
AngularJS基础 ng-paste 指令简单示例
2016/08/02 Javascript
Angularjs 设置全局变量的方法总结
2016/10/20 Javascript
JavaScript调试的多个必备小Tips
2017/01/15 Javascript
基于javascript实现数字英文验证码
2017/01/25 Javascript
js实现随机点名系统(实例讲解)
2017/10/18 Javascript
Vue 获取数组键名的方法
2018/06/21 Javascript
微信小程序身份证验证方法实现详解
2019/06/28 Javascript
详解JavaScript自定义函数
2020/07/29 Javascript
Python 时间操作例子和时间格式化参数小结
2014/04/24 Python
Python中的复制操作及copy模块中的浅拷贝与深拷贝方法
2016/07/02 Python
利用Python操作消息队列RabbitMQ的方法教程
2017/07/19 Python
微信跳一跳辅助python代码实现
2018/01/05 Python
python负载均衡的简单实现方法
2018/02/04 Python
python清除字符串前后空格函数的方法
2018/10/21 Python
python对于requests的封装方法详解
2019/01/03 Python
对Python中一维向量和一维向量转置相乘的方法详解
2019/08/26 Python
python使用SQLAlchemy操作MySQL
2020/01/02 Python
基于python实现检索标记敏感词并输出
2020/05/07 Python
重构Python代码的六个实例
2020/11/25 Python
使用python爬取抖音app视频的实例代码
2020/12/01 Python
HTML5 Convas APIs方法详解
2015/04/24 HTML / CSS
h5页面背景图很长要有滚动条滑动效果的实现
2021/01/27 HTML / CSS
如何用PHP实现邮件发送
2012/12/26 面试题
市场营销专业个人自荐信格式
2013/09/21 职场文书
一年级小学生评语
2014/04/22 职场文书
2016个人廉洁自律承诺书
2016/03/25 职场文书
想要创业,那么你做好准备了吗?
2019/07/01 职场文书