`

Ext TreePanel实现单选等功能

阅读更多
引用

在ext1.x里,树是没有checkbox的, 幸好在2.X版本里提供了这个功能, 在许多应用里, 带有checkbox的树使用还是很常见的

Ext2.X提供了简单的checkbox实现,但对于一些复杂的需求,如: 级联多选(选中父结点,自选中其所有子结点和所有父结点) , 单选等等, Ext2.X并没有帮我们实

还有最难解决的情况, 当树是异步的时候, 要想级联多选, 实现起来有些难度

在此, 通过对Ext.tree.TreeNodeUI进行扩展,这些问题都得到很好的解决

对 Ext.tree.TreeNodeUI 进行checkbox功能的扩展,后台返回的结点信息不用非要包含checked属性

扩展的功能点有:
一、支持只对树的叶子进行选择
    只有当返回的树结点属性leaf = true 时,结点才有checkbox可选
    使用时,只需在声明树时,加上属性 onlyLeafCheckable: true 既可,默认是false

二、支持对树的单选
    只允许选择一个结点
    使用时,只需在声明树时,加上属性 checkModel: "single" 既可

三、支持对树的级联多选
    当选择结点时,自动选择该结点下的所有子结点,或该结点的所有父结点(根结点除外),特别是支持异步,当子结点还没显示时,会从后台取得子结点,然后将其选中/取消选中
    使用时,只需在声明树时,加上属性 checkModel: "cascade" 或"parentCascade"或"childCascade"既可
    cascade :级联选中所有父结点和子结点
    parentCascade :级联选中所有父结点
    childCascade  :级联选中所有子结点

四、添加"check"事件
    该事件会在树结点的checkbox发生改变时触发
    使用时,只需给树注册事件,如:
    tree.on("check",function(node,checked){...});

默认情况下,checkModel为 'multiple',也就是多选;onlyLeafCheckable为false,所有结点都可选

使用方法:在loader里加上 baseAttrs:{uiProvider:Ext.ux.TreeCheckNodeUI} 既可.

例如:
Js代码
 var tree = new Ext.tree.TreePanel({  
     el:'tree-ct',  
     width:568,  
     height:300,  
     checkModel: 'cascade',   // 对树的级联多选  
     onlyLeafCheckable: false,//对树所有结点都可选  
     animate: false,  
     rootVisible: false,  
     autoScroll:true,  
         dwrCall:Tmplt.getTmpltTree,  
         baseAttrs: { uiProvider: Ext.ux.TreeCheckNodeUI } //添加uiProvider属性  
     }),  
     root: new Ext.tree.AsyncTreeNode({ id:'0' })  
 });  
 tree.on("check",function(node,checked){alert(node.text+" = "+checked)}); //注册"check"事件  
 tree.render();  

    var tree = new Ext.tree.TreePanel({
        el:'tree-ct',
        width:568,
        height:300,
        checkModel: 'cascade',   //对树的级联多选
        onlyLeafCheckable: false,//对树所有结点都可选
        animate: false,
        rootVisible: false,
        autoScroll:true,
        loader: new Ext.tree.DWRTreeLoader({
            dwrCall:Tmplt.getTmpltTree,
            baseAttrs: { uiProvider: Ext.ux.TreeCheckNodeUI }//添加uiProvider属性
        }),
        root: new Ext.tree.AsyncTreeNode({ id:'0' })
    });
    tree.on("check",function(node,checked){alert(node.text+" = "+checked)}); //注册"check"事件
    tree.render();


需要注意的是, 使用例子里的Tree 使用了Ext.tree.DWRTreeLoader这个扩展类,用来加载后台树结点,这和使用其它的loader没有区别的,

如果您使用其它的loader, 同样加上 baseAttrs: { uiProvider: Ext.ux.TreeCheckNodeUI } 就行了
实现单选功能:
this.on('checkchange',this.check,this);
getNodes:function(treePanel){
        var startNode = treePanel.getRootNode();
        var r = [];
        var f = function(){
                r.push(this);
        };

        startNode.cascade(f);
        return r;
},
check : function(node,bool) {
        if(!bool){
            return;
        }
		if(this.checkModel=='single'){
	        var nodes =this.getNodes(this);
	        if(nodes && nodes.length>0){
	            for(var i=0,len=nodes.length;i<len;i++){
	                if(nodes[i].id!=node.id){
	                    if(nodes[i].getUI().checkbox){
	                        nodes[i].getUI().checkbox.checked = false;
                                nodes[i].attributes.checked=false;
	                    }
	                }
	            }
	        }
		}
	}



http://www.iteye.com/topic/164426
分享到:
评论
1 楼 yuniannian 2010-08-03  
楼主太强了,今天刚好用到这个,谢谢哦

相关推荐

    Extjs 中的 Treepanel 实现菜单级联选中效果及实例代码

    TreePanel继承自Panel,在ExtJS中使用树控件含有丰富的属性和方法实现复杂的功能。其中Ext.tree.TreeNode代表一个树节点,比较常用的属性包括text、id、icon、checked等、异步树Ext.tree.AsyncTreeNode、树加载器Ext...

    comboxTree下拉树,实现单选功能

    本代码示例专注于实现ComboxTree的单选功能,即用户只能选择树中的一个节点,而不是多选。 EXT JS是一个强大的JavaScript UI库,它提供了丰富的组件和布局模式,用于构建富客户端应用程序。ComboBox是EXT JS中的一...

    Ext.net TreePanel的Checkbox操作及父子节点联动(修正)

    在EXT.NET框架中,TreePanel是一个非常重要的组件,它用于展示层次结构的数据,例如文件系统、组织结构等。本文将详细讲解如何实现TreePanel中的Checkbox操作以及父子节点间的联动效果,特别是针对之前存在的Bug进行...

    Extjs4下拉树菜单ComboBoxTree支持单选和多选并且支持展开选中指定节点的通用控件

    要实现单选功能,ComboBoxTree可能使用了Ext.selection.Model类,通过配置singleSelect选项来限制用户只能选择一个节点。单击一个节点时,其他已选中的节点将被自动取消选中。这在需要用户做出唯一选择的场景中非常...

    ext3.0中文API

    EXT3.0的FormPanel提供了多种表单元素,如文本字段、下拉列表、复选框和单选按钮等,以及表单验证和数据提交功能。API文档将指导开发者如何创建动态表单,处理用户输入,并与服务器进行数据交互。 Charts是EXT3.0中...

    ext中文帮助文档最终版

    7. **表单组件**:EXT 2.0提供了多种表单字段,如文本框、密码框、下拉列表、复选框和单选按钮,以及表单验证功能。 8. **Ajax和数据存储**:EXT内置了Ajax支持,方便与服务器进行异步通信。Store组件可以处理数据...

    ext树的控制选择和撤销,可以直接使用

    在实际应用中,开发人员需要根据具体需求来调整EXT树的配置,比如定义节点的渲染方式、处理节点的点击事件、实现撤销功能的栈管理等。EXT的API文档是学习和理解这些功能的宝贵资源,它提供了详尽的类和方法介绍,...

    Ext组件描述,各个组件含义

    - **功能描述**:Radio 是一个单选按钮控件,用户只能选择一个选项。 - **主要用途**:适用于需要用户从多个选项中选择一个的场景。 **2.26 Text Area (Ext.form.TextArea)** - **xtype**: `textarea` - **功能...

    Ext3.0的个人笔记及例子

    7. **TreePanel(树形面板)**:TreePanel用于展示层级结构的数据,可以用来创建文件系统浏览、组织结构图等。它支持动态加载、节点拖放、展开/折叠等功能。 8. **GridPanel(表格面板)**:GridPanel是用于展示二...

    Extjs复习笔记(十八)-- TreePanel

    这些文件通常用来实现具有复选框功能的TreePanel,让用户可以选择树形结构中的一个或多个节点。`check-tree.html`是HTML页面,它引入了必要的ExtJS库和我们的脚本文件。`check-tree.js`包含了ExtJS的代码,用于创建...

    Ext 动态树

    - Ext支持树形结构的拖放操作,通过`ddConfig`配置可以启用拖放功能,并实现节点的移动和重新排序。 6. **异步加载**: - 在大型数据集情况下,可以使用异步加载(lazy loading)来提高性能,只在需要时加载节点...

    ext简单例子

    EXT的ComboBox支持远程加载数据,可以实现动态过滤和自动补全功能。 7. **按钮(Button)**: Button组件用于触发某种操作,可以设置文字、图标、工具提示和点击事件。EXT的按钮支持不同状态(如禁用、加载中)和...

    关于extjs ext.tree

    你可以查看`ext-all.js`或`ext-all-debug.js`文件中关于TreePanel、TreeNode和TreeStore的相关代码,了解其内部实现机制。 7. **扩展与工具**: - 使用`Ext.tree.Column`可以为TreePanel添加列,展示更多节点信息...

    Ext中xtype和vtype.

    Ext 是一个功能强大的 JavaScript 框架,它提供了许多有用的组件和工具,使开发者可以快速构建复杂的 Web 应用程序。在 Ext 中,xtype 和 vtype 是两个非常重要的概念,它们分别用于定义组件的类型和验证规则。 ...

    ext Grid控件

    此外,EXT Grid也与其他EXT JS组件良好集成,例如可以配合TreePanel、FormPanel等构建复杂的界面布局。 总的来说,EXT Grid是Web开发中处理表格数据的重要工具,尤其在企业级应用中,其丰富的功能和高度定制化的...

    Ext各种标签 实用

    1. 表单元素:ExtJS提供了诸如文本框(TextField)、密码框(PasswordField)、选择框(ComboBox)、复选框(Checkbox)、单选按钮(RadioButton)等表单组件,它们支持验证、事件处理等功能,使得表单数据的收集和...

    Extjs教程_第八章_Tree(树)(2)

    - **Ext.tree.TreeEditor** 是一个内置工具,用于实现树节点的编辑功能。当你双击一个节点时,TreeEditor 会自动为该节点创建一个文本框(TextField)供用户编辑。 - 编辑完成后,并不会自动保存到服务器。你需要...

    extjs4 下拉菜单树 combobox+tree 支持单选多选

    本教程将深入讲解如何实现EXTJS4下的下拉菜单树,并支持单选和多选功能。 1. **EXTJS4的基础概念** - EXTJS是一个基于JavaScript的富客户端框架,提供了一系列强大的组件库,可以构建复杂的、数据驱动的Web应用...

    精通JS脚本之ExtJS框架.part1.rar

    5.2.7 Ext.MessageBox的其他功能 5.3 进度条组件 5.3.1 Ext.ProgressBar简介 5.3.2 手工模式的进度条 5.3.3 自动模式的进度条 5.3.4 自定义样式的进度条 5.4 工具栏和菜单栏 5.4.1 Ext.Toolbar简介 5.4.2 只...

    Extjs的tree

    TreePanel提供丰富的事件,如`checkchange`(复选框状态改变)、`beforeexpand`(展开前触发)、`expand`(展开后触发)等,开发人员可以通过监听这些事件来实现特定的业务逻辑。 6. **使用WCF服务** 当需要从...

Global site tag (gtag.js) - Google Analytics