Ext教程连载 - 普通树形控件
2009-09-29 08:00
357 查看
主要介绍ext树形控件的使用,这里先介绍普通的树形控件,即没有与服务端交互,通过自定义增加节点方式生成的树,下一节将会介绍异步加载的树,请关注。相信大家对windows树形菜单都非常熟悉,并且十分喜爱吧,如果用在自己的web项目中,一定可以带来绝佳的用户体验,在ext的树形菜单控件中可以实现直接定义的树和从服务器动态加载的树,前者通常用于固定菜单,后者多用于实现动态加载的菜单,如cms系统的分类管理,这里我们先介绍普通树形控件,下一章介绍异步加载的树,看下面的代码:
代码:
运行以上代码,将有如下效果:
treeNode是可以灵活定义的,伟大的jack究竟做了什么?来看看下面这段代码:
代码:
请看效果:
最后我们看看如何自定义树节点图标及添加节点超链接,当然,ext树形控件非常灵活,具体的您还是要参照api哦,我们再改下代码:
代码:
看下效果:
怎么样?是不是很强大,呵呵,下一章还有更强大的,异步加载的树形控件:)
代码:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <html> <head> <title> New Document </title> <link rel="stylesheet" type="text/css" href="ext/resources/css/ext-all.css" /> <script type="text/javascript" src="ext/adapter/ext/ext-base.js"></script> <script type="text/javascript" src="ext/ext-all.js"></script> </head> <body> <script type="text/javascript"> Ext.onReady(function(){ //定义树的跟节点 var root=new Ext.tree.TreeNode({ id:"root",//根节点id text:"我是树根" }); //定义树节点 var c1=new Ext.tree.TreeNode({ id:'c1',//子结点id text:'我是大儿子' }); var c2=new Ext.tree.TreeNode({ id:'c2', text:'我是小儿子' }); var c22=new Ext.tree.TreeNode({ id:'c22', text:'我是大孙子' }); root.appendChild(c1);//为根节点增加子结点c1 root.appendChild(c2);//为c1增加子节点c2,相信你已经找到规律了吧^_^ c1.appendChild(c22);//为c1增加子节点c22 //生成树形面板 var tree=new Ext.tree.TreePanel({ renderTo:"show", root:root,//定位到根节点 animate:true,//开启动画效果 enableDD:false,//不允许子节点拖动 border:false,//没有边框 rootVisible:true//设为false将隐藏根节点,很多情况下,我们选择隐藏根节点增加美观性 }); }) </script> <div id="show"></div> </body> </html>
运行以上代码,将有如下效果:
treeNode是可以灵活定义的,伟大的jack究竟做了什么?来看看下面这段代码:
代码:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <html> <head> <title> New Document </title> <link rel="stylesheet" type="text/css" href="ext/resources/css/ext-all.css" /> <script type="text/javascript" src="ext/adapter/ext/ext-base.js"></script> <script type="text/javascript" src="ext/ext-all.js"></script> </head> <body> <script type="text/javascript"> Ext.onReady(function(){ //定义树的跟节点 var root=new Ext.tree.TreeNode({ id:"root",//根节点id text:"我是树根" }); //定义树节点 var c1=new Ext.tree.TreeNode({ id:'c1',//子结点id text:'我是大儿子' }); var c2=new Ext.tree.TreeNode({ id:'c2', text:'我是小儿子,请点击我' }); var c22=new Ext.tree.TreeNode({ id:'c22', text:'我是大孙子' }); root.appendChild(c1);//为根节点增加子结点c1 root.appendChild(c2);//为c1增加子节点c2,相信你已经找到规律了吧^_^ c1.appendChild(c22);//为c1增加子节点c22 //生成树形面板 var tree=new Ext.tree.TreePanel({ renderTo:"show", root:root,//定位到根节点 animate:true,//开启动画效果 enableDD:false,//不允许子节点拖动 border:false,//没有边框 rootVisible:true//设为false将隐藏根节点,很多情况下,我们选择隐藏根节点增加美观性 }); //增加点击事件 c2.on('click',function(node){ alert('我是:"'+node.text+'",我的id是:"'+node.id+'"');//这里增加你所需要的点击事件 }); }) </script> <div id="show"></div> </body> </html>
请看效果:
最后我们看看如何自定义树节点图标及添加节点超链接,当然,ext树形控件非常灵活,具体的您还是要参照api哦,我们再改下代码:
代码:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <html> <head> <title> New Document </title> <link rel="stylesheet" type="text/css" href="ext/resources/css/ext-all.css" /> <script type="text/javascript" src="ext/adapter/ext/ext-base.js"></script> <script type="text/javascript" src="ext/ext-all.js"></script> </head> <body> <script type="text/javascript"> Ext.onReady(function(){ //定义树的跟节点 var root=new Ext.tree.TreeNode({ id:"root",//根节点id text:"我是树根" }); //定义树节点 var c1=new Ext.tree.TreeNode({ id:'c1',//子结点id text:'我是大儿子' }); var c2=new Ext.tree.TreeNode({ id:'c2', text:'我是小儿子,请点击我', icon:'im2.gif',//自定义节点图标 href:'http://www.extshow.com/',//添加超链接 hrefTarget:'_blank'//新窗口打开链接 }); var c22=new Ext.tree.TreeNode({ id:'c22', text:'我是大孙子' }); root.appendChild(c1);//为根节点增加子结点c1 root.appendChild(c2);//为c1增加子节点c2,相信你已经找到规律了吧^_^ c1.appendChild(c22);//为c1增加子节点c22 //生成树形面板 var tree=new Ext.tree.TreePanel({ renderTo:"show", root:root,//定位到根节点 animate:true,//开启动画效果 enableDD:false,//不允许子节点拖动 border:false,//没有边框 rootVisible:true//设为false将隐藏根节点,很多情况下,我们选择隐藏根节点增加美观性 }); }) </script> <div id="show"></div> </body> </html>
看下效果:
怎么样?是不是很强大,呵呵,下一章还有更强大的,异步加载的树形控件:)
相关文章推荐
- Ext教程连载 - 带右键菜单的树
- Ext教程连载 - 异步加载的树
- [JAVASCRIPT][EXTJS]直接用JSON创建树形控件(Ext.tree.TreePanel )(转)
- Ext普通树型控件
- Ext教程连载 - GridPanel基本表格
- [JAVASCRIPT][EXTJS]直接用JSON创建树形控件(Ext.tree.TreePanel )
- EXT公共控件之带树形结构的ComboBox
- Ext教程连载 - Border区域布局
- Ext教程连载 - FormPanel基本表单
- Ext教程连载 - Fit布局
- Ext教程连载 - 带分页的表格
- Ext教程连载 - Accordion布局
- Ext教程连载 - MessageBox对话框
- Ext.tree树形控件设置
- Ext教程连载 - Column列布局
- Ext教程连载 作用域
- Ext教程连载 - Form布局
- Extjs4 获取items子控件时使用Ext.getCmp返回undefined
- 重写ext的TextField控件,增加鼠标悬浮提示和控件后加说明文字
- 【原创·教程·连载】《Microsoft SQL Server 2008 Reporting Services应用系列》 免费发布