Ext教程 arrow Ext控件使用 arrow 普通树形控件
 
     
普通树形控件
  2008-04-12
主要介绍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>

   看下效果:

 

   怎么样?是不是很强大,呵呵,下一章还有更强大的,异步加载的树形控件:)
< 上一篇   下一篇 >
   
 
 
 
Copyright Infotmation overhere. | designed by Magicbox from Mambochina
曼波整站系统 基于 Mambo 开发,是免费的自由软件,遵循 GNU/GPL 开源许可协议。
曼波整站系统5.4.0Mambo中国Mambo Resource 联合增强开发。  闽ICP备08005204号