利用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 相关文章推荐
利用毫秒减值计算时长的js代码
Sep 22 Javascript
jquery 删除cookie失效的解决方法
Nov 12 Javascript
JS Attribute属性操作详解
May 19 Javascript
JS给swf传参数的实现方法
Sep 13 Javascript
bootstrap weebox 支持ajax的模态弹出框
Feb 23 Javascript
详解AngularJS ui-sref的简单使用
Apr 24 Javascript
axios进阶实践之利用最优雅的方式写ajax请求
Dec 20 Javascript
vue todo-list组件发布到npm上的方法
Apr 04 Javascript
JS引用传递与值传递的区别与用法分析
Jun 01 Javascript
微信小程序自定义弹窗实现详解(可通用)
Jul 04 Javascript
JS的时间格式化和时间戳转换函数示例详解
Jul 27 Javascript
vue使用element-ui按需引入
May 20 Vue.js
用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合并静态文件详解
2014/11/14 PHP
浅谈PHP中output_buffering
2015/07/13 PHP
PHP如何使用Memcached
2016/04/05 PHP
PHP等比例压缩图片的实例代码
2018/07/26 PHP
syntaxhighlighter 使用方法
2007/07/02 Javascript
jQuery 源码分析笔记(6) jQuery.data
2011/06/08 Javascript
JavaScript作用域链使用介绍
2013/08/29 Javascript
Jquery图片延迟加载插件jquery.lazyload.js的使用方法
2014/05/21 Javascript
node.js中的events.EventEmitter.listenerCount方法使用说明
2014/12/08 Javascript
javascript+HTML5自定义元素播放焦点图动画
2016/02/21 Javascript
JavaScript暂停和继续定时器的实现方法
2016/07/18 Javascript
基于JavaScript实现飘落星星特效
2017/08/10 Javascript
在Vue项目中使用d3.js的实例代码
2018/05/01 Javascript
jQuery动态移除与增加onclick属性的方法详解
2018/06/07 jQuery
js实现一个页面多个倒计时的3种方法
2019/02/25 Javascript
使用js在layui中实现上传图片压缩
2019/06/18 Javascript
使用npm命令提示: 'npm' 不是内部或外部命令,也不是可运行的程序的处理方法
2020/05/14 Javascript
Element Badge标记的使用方法
2020/07/27 Javascript
[37:03]完美世界DOTA2联赛PWL S3 INK ICE vs GXR 第二场 12.16
2020/12/18 DOTA
Python爬虫框架Scrapy安装使用步骤
2014/04/01 Python
Python回文字符串及回文数字判定功能示例
2018/03/20 Python
python引用(import)某个模块提示没找到对应模块的解决方法
2019/01/19 Python
自学python的建议和周期预算
2019/01/30 Python
python opencv将图片转为灰度图的方法示例
2019/07/31 Python
TensorFlow tensor的拼接实例
2020/01/19 Python
python随机模块random的22种函数(小结)
2020/05/15 Python
理解Django 中Call Stack机制的小Demo
2020/09/01 Python
pyspark对Mysql数据库进行读写的实现
2020/12/30 Python
英国工具中心:UK Tool Centre
2017/07/10 全球购物
英国领先的鞋类零售商和顶级品牌的官方零售商:Wynsors
2020/02/17 全球购物
外贸业务员求职信范文
2013/12/12 职场文书
关于运动会广播稿50字
2014/10/18 职场文书
2016年情人节问候语
2015/11/11 职场文书
2016年国庆节新闻稿范文
2015/11/25 职场文书
2019年年中工作总结讲话稿模板
2019/03/25 职场文书
vue组件vue-esign实现电子签名
2022/04/21 Vue.js