利用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 相关文章推荐
DB.ASP 用Javascript写ASP很灵活很好用很easy
Jul 31 Javascript
jquery中插件实现自动添加用户的具体代码
Nov 15 Javascript
js 获取、清空input type=&quot;file&quot;的值(示例代码)
Dec 24 Javascript
javascript动态修改Li节点值的方法
Jan 20 Javascript
微信WeixinJSBridge API使用实例
May 25 Javascript
Bootstrap Paginator分页插件使用方法详解
May 30 Javascript
JavaScript语言精粹经典实例(整理篇)
Jun 07 Javascript
Vue.js学习示例分享
Feb 05 Javascript
在 React、Vue项目中使用SVG的方法
Feb 09 Javascript
vue-cli3配置与跨域处理方法
Aug 17 Javascript
JS扁平化输出数组的2种方法解析
Sep 17 Javascript
Vue与React的区别和优势对比
Dec 18 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对文件进行加锁、解锁实例
2015/01/23 PHP
weiphp微信公众平台授权设置
2016/01/04 PHP
漂亮的仿flash菜单,来自蓝色经典
2006/06/26 Javascript
javascript IFrame 强制刷新代码
2009/07/23 Javascript
js验证是否为数字的总结
2013/04/14 Javascript
Node.js中安全调用系统命令的方法(避免注入安全漏洞)
2014/12/05 Javascript
在JavaScript中用getMinutes()方法返回指定的分时刻
2015/06/10 Javascript
JavaScript中数据结构与算法(五):经典KMP算法
2015/06/19 Javascript
javascript父子页面通讯实例详解
2015/07/17 Javascript
JavaScript 对象详细整理总结
2016/09/29 Javascript
JS正则替换掉小括号及内容的方法
2016/11/29 Javascript
jquery实现(textarea)placeholder自动换行
2016/12/22 Javascript
vue实现ToDoList简单实例
2017/02/07 Javascript
使用Karma做vue组件单元测试的实现
2020/01/16 Javascript
element 动态合并表格的步骤
2020/12/31 Javascript
Python使用filetype精确判断文件类型
2017/07/02 Python
运用TensorFlow进行简单实现线性回归、梯度下降示例
2018/03/05 Python
Django中更改默认数据库为mysql的方法示例
2018/12/05 Python
python合并已经存在的sheet数据到新sheet的方法
2018/12/11 Python
python机器学习库scikit-learn:SVR的基本应用
2019/06/26 Python
Python集成开发工具Pycharm的安装和使用详解
2020/03/18 Python
Python中flatten( ),matrix.A用法说明
2020/07/05 Python
python通用数据库操作工具 pydbclib的使用简介
2020/12/21 Python
HTML table 表格边框的实现思路
2019/10/12 HTML / CSS
ALEX AND ANI:手镯,项链,耳环和更多
2017/04/20 全球购物
JD Sports马来西亚:英国领先的运动鞋和运动服饰零售商
2018/03/13 全球购物
Nordgreen手表德国官方网站:丹麦极简主义手表
2019/10/31 全球购物
AJAX都有哪些有点和缺点
2012/11/03 面试题
会计学财务管理专业个人的自我评价
2013/10/19 职场文书
《孔子拜师》教学反思
2014/02/24 职场文书
工厂搬迁方案
2014/05/11 职场文书
酒店服务员岗位职责
2015/02/09 职场文书
网络销售员岗位职责
2015/04/11 职场文书
java调用Restful接口的三种方法
2021/08/23 Java/Android
MySQL分区路径子分区再分区
2022/04/13 MySQL
德生TECSUN S-2000使用手册文字版
2022/05/10 无线电