`
finally_m
  • 浏览: 69847 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

(十四)树型控件

    博客分类:
  • AJAX
阅读更多

树型控件
(1) TreePanel
在应用程序中,我们经常会涉及到要显示或处理树状结构的对象信息,比如部门信息、地区信息,或者是树状的菜单信息,操作系统中的文件夹信息等。对于传统的html 页面来说,要自己实现显示树比较困难,需要写很多的javascript,特别是对于基于Ajax 异步加载的树来说,不但涉及到Ajax 数据加载及处理技术,还需要考虑跨浏览器支持等,处理起来非常麻烦。ExtJS 中提供了现存的树控件,通过这些控件可以在B/S 应用中快速开发出包含树结构信息的应用。

TreePanel基本使用
树控件由Ext.tree.TreePanel 类定义,控件的名称为treepanel,TreePanel 类继承自Panel面板。在ExtJS 中使用树控件其实非常简单,我们先来看下面的代码:
Ext.onReady(function(){
 var root=new Ext.tree.TreeNode({id:"root",text:"树的根"});
 root.appendChild(new Ext.tree.TreeNode({id:"c1",text:"子节点"}));
 var tree=new Ext.tree.TreePanel({renderTo:"mydiv",root:root,width:100});
});

代码的第一句使用new Ext.tree.TreeNode 类来创建一个树节点,第二句使用树节点的root 的appendChild 方法来往该节点中加入一个子节点,最后直接使用new Ext.tree.TreePanel来创建一个树面板,要树面板的初始化参数中指定树的root 属性值为前面创建的root 节点,也就是树根节点。

树的节点信息。ExtJS 的树控件提供了对这种功能的支持,你只需要在创建树控件的时候,通过给树指定一个节点加载器,可以用来从服务器端动态加载树的节点信息。我们来看下面的代码:

treedata.js文件用来存放节点信息:
[{
 id: 1,
 text: '节点1',
 leaf: true
},{
 id: 2,
 text: '节点2',
 children: [{
  id: 3,
  text: '节点21',
  leaf: true
 }]
}]
注意:treedata.js文件中如果有中文,需要修改js文件的编码(在ecliipse中),建议使用UTF-8编码。

下面通过加载treedata.js文件构造树:
Ext.onReady(function(){
 var root=new Ext.tree.AsyncTreeNode({id:"root",text:"根节点"});
 var tree=new Ext.tree.TreePanel({
  renderTo:"mydiv",
  root:root,
  loader: new Ext.tree.TreeLoader({url:"treedata.js"}),
  width:300,
  height:200
 });
});

<div id=”mydiv”></div>

执行上面的程序,可以得到一棵异步加载子节点的树,点击“根节点”会到服务器端加载子节点。

事件处理
仅仅能显示一棵树还不够,我们一般还需要在用户点击树节点的时候执行相应的东西,比如打开某一个连接,执行某一个函数等,这就需要使用到事件处理。比如下面的代码:
   Ext.onReady(function(){
  var root=new Ext.tree.TreeNode({
   id:"root",
   text:"树根"});
  var c1=new Ext.tree.TreeNode({
   id:"c1",
   text:"子节点"
  });
  root.appendChild(c1);
  var tree=new Ext.tree.TreePanel({
   renderTo:"mydiv",
   root:root,
   width:100
  });
  //给树添加事件
  tree.on("click",function(node,event){
   alert("您点击了"+node.text);
  });
  //给c1节点添加事件
  c1.on("click",function(node,event){
   alert("您点击了"+node.text);
  });
 });


<div id=”mydiv”></div>

执行上面的程序,当用户点击树控件中的任意节点时,都会弹出一个提示信息框,当用户点击c1 这个子节点时,会弹出两次提示信息框。因为我们除了指定tree 的click 事件响应函数以外,另外又给node 节点指定单独的事件响应函数。

如果只是要实现当点击树节点时跳到某一个指定url 的功能则非常简单。看下面的代码:
Ext.onReady(function(){
 var root=new Ext.tree.TreeNode({
  id:"root",
  href:"http://www.extjs.com",
  hrefTarget:"_blank",
  text:"树根"
 });
 var c1=new Ext.tree.TreeNode({
  id:"c1",
  href:"http://www.iteye.com",
  hrefTarget:"_blank",
  text:"子节点"
 });
 root.appendChild(c1);
 var tree=new Ext.tree.TreePanel({
  renderTo:"mydiv",
  root:root,
  width:100
 });
});

<div id=”mydiv”></div>

点击树节点,将会在浏览新窗口中打开节点中href 指定的链接。

(2) TreeNode
在ExtJS 中,不管是叶子节点还是非叶子节点,都统一用TreeNode 表表示树的节点。在ExtJS 中,有两种类型的树节点。一种节点是普通的简单树节点,由Ext.tree.TreeNode 定义,另外一种是需要异步加载子节点信息的树节点,该类由Ext.tree.AsyncTreeNode 定义。
看下面的代码:
Ext.onReady(function(){
 var tree=new Ext.tree.TreePanel({
  renderTo:"mydiv",
  root:new Ext.tree.AsyncTreeNode({
   text:"根节点"
  }),
  width:100
 });
});

<div id=”mydiv”></div>

执行程序,点击树中的“根节点”则会一直发现树会尝试加载这个节点的子节点,由这里没有指定树的加载器,所以“根节点”会变成一直处于加载的状态。

对于普通的TreeNode 来说,可以通过调用节点的appendChild、removeChild 等方法来往该节点中加入子节点或删除子节点等操作。
TreeNode 与AsyncTreeNode 可以同时使用,比如下面的代码:
Ext.onReady(function(){
 var root=new Ext.tree.TreeNode({
  id:"root",
  text:"树根"
 });
 var c1=new Ext.tree.TreeNode({
  text:"node1"
 })
 var c2=new Ext.tree.AsyncTreeNode({
  text:"node2"
 });
 root.appendChild(c1);
 root.appendChild(c2);
 var tree=new Ext.tree.TreePanel({
  renderTo:"mydiv",
  root:root,
  width:300,
  loader:new Ext.tree.TreeLoader({
   url:"treedata.js"
  })
 });
});
treedata.js请参考之前的内容。

另外要在树以外的程序中得到当前选择的节点,可以通过TreePanel 的getSelectionModel 方法来获得,该方法默认返回的是Ext.tree.DefaultSelectionModel 对象,DefaultSelectionModel 的getSelectedNode 方法返回当前选择的树节点。比如要得到树tree 中中当前选择节点,代码如下:
   Ext.onReady(function(){
  var root=new Ext.tree.TreeNode({
   id:"root",
   text:"树根"
  });
  var c1=new Ext.tree.TreeNode({
   text:"子节点1"
  });
  var c2=new Ext.tree.AsyncTreeNode({
   text:"子节点2"
  });
  root.appendChild(c1);
  root.appendChild(c2);
  var tree=new Ext.tree.TreePanel({
   renderTo:"mydiv",
   root:root,
   width:300,
   loader:new Ext.tree.TreeLoader({
    url:"ext-2.0/treedata.js"
   })
  });
  Ext.get("btn").on("click",function(node,event){
   alert(tree.getSelectionModel().getSelectedNode().text);
  });
 });

    <div id="mydiv"></div>
     <br/>
     <input type="button" id="btn" value="获取当前选中的节点"/>

(3) TreeLoader
对于ExtJS 中的树来说,树加载器TreeLoader 是一个比较关键的部件,树加载器由Ext.tree.TreeLoader 类定义,只有AsyncTreeNode 才会使用TreeLoader。看下面的代码:
Ext.onReady(function(){
 var loader=new Ext.tree.TreeLoader({
  url:"treedata.js"
 });
 var root=new Ext.tree.AsyncTreeNode({
  id:"root",
  text:"根节点",
  loader:loader
 });
 var tree=new Ext.tree.TreePanel({
  renderTo:"mydiv",
  root:root,
  width:100
 });
});
首先我们使用Ext.tree.TreeLoader 来初始化了一个TreeLoader 对象,构造函数中的配置参数url 表示获得树节点信息的url 。然后在初始化根节点的时候我们使用的是AsyncTreeNode,在该节点中指定该节点的laoder 为前面定义的loader。执行这段程序,在点击“根节点”时,会从服务器端指定root 节点的子节点信息。

分享到:
评论

相关推荐

    变色的树型控件 变色的树型控件 变色的树型控件

    在IT领域,树型控件(Tree View Control)是一种常见的用户界面元素,广泛应用于各种操作系统和应用程序中。这种控件以树状结构显示数据,通常包含可展开/折叠的节点,便于用户浏览和操作层次化的信息。在"变色的...

    JS 下拉框树型控件.rar

    在JavaScript(JS)开发中,下拉框树型控件是一种常见的交互元素,它结合了传统的下拉框和树形结构,通常用于显示层级关系的数据。这种控件在用户界面设计中非常有用,例如在选择组织结构、地区层级或者分类时。在本...

    vc树型控件拖动的完美实现.zip

    在VC++编程环境中,树型控件(Tree Control)是一种常用的数据展示组件,它能够以层级结构显示数据,常用于文件浏览器、系统设置等界面。本文将深入探讨如何在Visual C++中完美实现树型控件的拖动功能,使用户能够...

    树型控件,实现数据库读取数据到树型控件,并且右键实现添加、修改、删除功能

    在IT领域,尤其是在Windows应用程序开发中,经常需要与用户界面元素打交道,如树型控件(Tree Control)。本文将深入探讨如何实现一个树型控件,通过从数据库中读取数据并显示,同时提供右键菜单来实现添加、修改和...

    datawindow树型控件.rar

    在本压缩包“datawindow树型控件.rar”中,包含了一系列与在PowerBuilder中创建和使用树型结构DataWindow相关的资源。这些资源旨在帮助开发者理解和应用DataWindow树控件,从而提供更丰富的用户界面体验。 1. **...

    HTML树型控件.zip_html格式目录树

    例如,使用`$(selector).zTree(options)`来初始化树型控件,其中`options`是配置项,用于设置树的各种行为和样式。 4. **zTree的功能** - **设置**:压缩包中的`setting设置`可能包含zTree的配置项,用于定制树的...

    XML 树型控件代码.rar_html_html 树_html 树型_树型控件

    树型控件通常用于显示层次结构的数据,例如文件系统、组织结构或者菜单导航。 首先,我们需要理解XML的基本结构。XML文档由元素(Element)、属性(Attribute)和文本内容组成。元素是XML文档的构建块,以尖括号...

    vc树型控件与列表控件的应用

    在VC++编程环境中,树型控件(CTreeCtrl)和列表控件(CListCtrl)是两种常用的数据展示控件,它们在Windows应用程序中扮演着重要的角色。本篇文章将深入探讨这两种控件的使用方法及其在文件读取与存储中的应用。 ...

    check_item_tree.zip_tree 图标_tree控件,图标_树型_树型控件

    "check_item_tree.zip_tree 图标_tree控件,图标_树型_树型控件"这个标题所涉及的是一个特定类型的UI组件,即带有复选框的树形控件。这种控件在各种应用程序中广泛应用,尤其是那些需要展示层次结构数据的情况,如...

    js树型控件(附源码)

    在Web开发中,树型控件是一种常见的UI元素,用于显示具有层级结构的数据,如目录、组织架构或文件系统。这个资源提供了一个基于JavaScript实现的树型控件,它可以帮助开发者在网页上创建交互式的、可展开/折叠的节点...

    dw中使用树型控件适合用于pb9.0

    其中,“树型控件”(TreeView)是一种常用的数据结构,它以层次化的节点形式显示数据,非常适合用于表示具有层级关系的信息,如目录结构、组织架构或者产品分类等。本篇将详细讲解如何在PB9中使用数据窗口创建和...

    8个vc树型控件实例

    在VC++编程环境中,树型控件(Tree Control)是一种常用的数据展示组件,它能够以层级结构的形式显示数据,常用于文件系统、目录结构或自定义数据组织的展示。本篇将通过8个实例深入探讨VC++中树型控件的应用。 1. ...

    JavaScript 树型控件源码

    JavaScript树型控件是一种在网页上展示层次结构数据的交互组件,它通常用于文件系统、组织结构图或者导航菜单等场景。在这个“JavaScript 树型控件源码”中,我们可以期待找到一个实现这种功能的代码库。接下来,...

    用js写的树型控件,非常好用哦

    在IT领域,树型控件是一种常见的用户界面元素,它以树状结构展示数据,使得层级关系一目了然。本项目提供了一个基于JavaScript编写的树型控件,具有高度可定制性和实用性。 首先,我们要了解JavaScript(js)是Web...

    vc 树型控件的背景位图

    【VC树型控件的背景位图实现】 在VC++编程中,树型控件(CTreeCtrl)是一种常见的用户界面元素,它用于展现层次化的数据结构,类似于Windows资源管理器中的目录结构。为了使树型控件更具视觉吸引力,有时我们需要...

    Dtree_树型控件

    在IT行业中,树型控件(Treeview)是一种常见的用户界面元素,用于展示层次结构的数据。在Java中,实现树型控件的功能通常会用到Java Swing或JavaFX这两个库。"Dtree_树型控件"可能是指一个特定的Java实现,用于创建...

    将数据库中的内容加入树型控件中,通过建立数据库,再与树型控件

    树型控件是一种常见的UI元素,它可以清晰地呈现出层次结构的信息,非常适合用来显示数据库中的分类数据。在这个场景下,我们将讨论如何将数据库中的内容加入到树型控件中,以及这一过程涉及到的关键技术和步骤。 ...

    ASP.NET树型控件应用

    ASP.NET树型控件是网页开发中的重要组件,主要用于展示层次结构的数据,如组织结构、文件目录等。在本文中,我们将深入探讨如何在ASP.NET中应用树型控件,并结合数据库实现数据的动态绑定。 首先,理解ASP.NET树型...

    树型控件(TreeView)的使用

    树型控件(TreeView)是GUI(图形用户界面)中常用的一种控件,它以树状结构展示数据,常用于文件系统浏览、菜单系统、层级关系的显示等场景。在Windows编程中,如使用.NET Framework或MFC,都可以找到对TreeView的...

    VC中实现带有背景位图的树型控件

    ### VC中实现带有背景位图的树型控件 #### 一、背景与概述 在很多应用程序中,为了提升用户体验及界面美观度,开发者经常会在树型控件中加入背景位图。对于Visual C++(VC)编程爱好者来说,虽然MFC提供了内置的...

Global site tag (gtag.js) - Google Analytics