• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
鼎盛工作室
每天提高一点点,每天积累一点点,每天一点进步,有目标有计划的奋斗一生,每天追逐梦想,软件人生,人生软件。
博客园    首页    新随笔    联系   管理    订阅  订阅
Ext教程连载 - 普通树形控件
主要介绍ext树形控件的使用,这里先介绍普通的树形控件,即没有与服务端交互,通过自定义增加节点方式生成的树,下一节将会介绍异步加载的树,请关注。相信大家对windows树形菜单都非常熟悉,并且十分喜爱吧,如果用在自己的web项目中,一定可以带来绝佳的用户体验,在ext的树形菜单控件中可以实现直接定义的树和从服务器动态加载的树,前者通常用于固定菜单,后者多用于实现动态加载的菜单,如cms系统的分类管理,这里我们先介绍普通树形控件,下一章介绍异步加载的树,看下面的代码:

代码:
<!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>


看下效果:



怎么样?是不是很强大,呵呵,下一章还有更强大的,异步加载的树形控件:)
posted on 2009-09-29 08:00  鼎盛工作室  阅读(389)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3