`
cfnet
  • 浏览: 48107 次
  • 性别: Icon_minigender_1
  • 来自: 合肥
社区版块
存档分类
最新评论

Ext Tree之拖动排序并保存到数据库

阅读更多

Ext Tree的拖动功能,主要包括两方面,同级别节点的拖动和跃级拖动.

Ext Tree提供的响应拖动操作的事件还是比较多的.

Ext Tree demo里面,使用movenode : ( Tree tree, Node node, Node oldParent, Node newParent, Number index ) 来响应节点的拖动操作,在Ext.tree.TreePanel的定义中,加入如下代码,响应拖动操作:

01.tree.on('movenode',function(tree,node,oldParent,newParent,index){
02.            Ext.Ajax.request({
03.                url:base.path+'example/extTreeAction!move.do',
04.                params:{
05.                 nodeId:node.id,
06.                 oldParentId:oldParent.id,
07.                 newParentId:newParent.id,
08.                 index:index
09.                }
10.            });
11.        });

在拖动的时候,主要通过发送ajax请求,到后台,进行数据的同步修改.

在action 中,使用如下代码:

01./**
02.     * 移动节点
03.     * @return
04.     */
05.    public String move(){
06.        Map params=this.getParameterMap();
07.        String index=params.get("index").toString();
08.        String oldParentId=params.get("oldParentId").toString();
09.        String newParentId=params.get("newParentId").toString();
10.        String nodeId=params.get("nodeId").toString();
11.        this.getBaseService().saveMoveNode(nodeId, oldParentId, newParentId, index);
12.        return null;
13.    }

在service,进行节点的索引,父节点的修改,来执行拖动操作数据到数据库的同步.节点的拖动,像上面说的,分为同级和跃级,同级拖动中,又分为向上拖动和向下拖动,而跃级拖动中,需要处理父节点的变更等事宜,同时,要分别处理原父节点下剩余子节点的索引变更,新父节点下其它子节点的索引变更等问题.:

001./**
002.     * 移动节点时,适时保存节点排序到数据库 节点排序规则,同级节点按0-x排序,中间不空缺.
003.     *
004.     * @param nodeId
005.     * @param oldParentId
006.     * @param newParentId
007.     * @param index
008.     *            节点的新索引顺序
009.     */
010.    public void saveMoveNode(String nodeId, String oldParentId, String newParentId, String index)
011.    {
012.        Page page = this.getPageByProperty(null, null, null);
013.        TreeUtils treeUtils = new TreeUtils(page.getItems());
014.        ExtTree tree = this.get(nodeId);
015.        ExtTree parent = tree.getParent();
016.        List nodes = null;
017.        Integer oldOrderIndex = tree.getOrder();
018.        Integer newOrderIndex = Integer.parseInt(index);
019.        // 如果是同级移动
020.        if (oldParentId.equals(newParentId))
021.        {
022.            if (null != parent)
023.            {
024.                nodes = treeUtils.getDirectChildrenTrees(treeUtils.getTransferedTrees(), parent.getId());
025.            } else
026.            {
027.                nodes = treeUtils.getAllParents(treeUtils.getTransferedTrees());
028.            }
029.            // 如果是向下移动
030.            if (newOrderIndex.intValue() > oldOrderIndex.intValue())
031.            {
032.                if (CollectionUtils.isNotEmpty(nodes))
033.                {
034.                    for (int i = oldOrderIndex + 1; i < newOrderIndex + 1; i++)
035.                    {
036.                        Map map = (Map) nodes.get(i);
037.                        ExtTree temp = this.get(map.get(StringPool.TREE_ID).toString());
038.                        if (null != temp)
039.                        {
040.                            temp.setOrder(temp.getOrder().intValue() - 1);
041.                            this.save(temp);
042.                        }
043.                    }
044.                }
045.                tree.setOrder(newOrderIndex);
046.                this.save(tree);
047.            } else
048.            {
049.                // 如果向上移动
050.                if (CollectionUtils.isNotEmpty(nodes))
051.                {
052.                    for (int i = newOrderIndex; i < oldOrderIndex; i++)
053.                    {
054.                        Map map = (Map) nodes.get(i);
055.                        ExtTree temp = this.get(map.get(StringPool.TREE_ID).toString());
056.                        if (null != temp)
057.                        {
058.                            temp.setOrder(temp.getOrder().intValue() + 1);
059.                            this.save(temp);
060.                        }
061.                    }
062.                }
063.                tree.setOrder(newOrderIndex);
064.                this.save(tree);
065.            }
066.        } else
067.        {
068.            // 如果是跃级移动
069.            // 对节点原位置进行处理
070.            if (oldParentId.equals(StringPool.TREE_ROOT_ID))
071.            {
072.                nodes = treeUtils.getAllParents(treeUtils.getTransferedTrees());
073.            } else
074.            {
075.                nodes = treeUtils.getDirectChildrenTrees(treeUtils.getTransferedTrees(), oldParentId);
076.            }
077. 
078.            if (CollectionUtils.isNotEmpty(nodes) && nodes.size() > 1)
079.            {
080.                for (int i = tree.getOrder() + 1; i < nodes.size(); i++)
081.                {
082.                    Map map = (Map) nodes.get(i);
083.                    ExtTree temp = this.get(map.get(StringPool.TREE_ID).toString());
084.                    temp.setOrder(temp.getOrder().intValue() - 1);
085.                    this.save(temp);
086.                }
087.            }
088.            // 对新节点位置进行处理
089.            if (newParentId.equals(StringPool.TREE_ROOT_ID))
090.            {
091.                nodes = treeUtils.getAllParents(treeUtils.getTransferedTrees());
092.            } else
093.            {
094.                nodes = treeUtils.getDirectChildrenTrees(treeUtils.getTransferedTrees(), newParentId);
095.            }
096.            if (CollectionUtils.isNotEmpty(nodes))
097.            {
098.                for (int i = newOrderIndex; i < nodes.size(); i++)
099.                {
100.                    Map map = (Map) nodes.get(i);
101.                    ExtTree temp = this.get(map.get(StringPool.TREE_ID).toString());
102.                    temp.setOrder(temp.getOrder().intValue() + 1);
103.                  &n <script src="../scripts/lib/tinymce/jscripts/tiny_mce/themes/advanced/langs/en.js" type="text/javascript"></script><script src="../scripts/lib/tinymce/jscripts/tiny_mce/plugins/syntaxhl/langs/en.js" type="text/javascript"></script> bsp; this.save(temp);
104.                }
105.            }
106.            tree.setOrder(newOrderIndex);
107.            parent = this.get(newParentId);
108.            tree.setParent(parent);
109.            this.save(tree);
110.        }
111.    }

 

在Ext 2.2的官方文档中,可以看到的拖动事件如下:

movenode : ( Tree tree, Node node, Node oldParent, Node newParent, Number index )

Fires when a node is moved to a new location in the tree
Fires when a node is moved to a new location in the tree
Listeners will be called with the following arguments:
  • tree : Tree
    The owner tree
  • node : Node
    The node moved
  • oldParent : Node
    The old parent of this node
  • newParent : Node
    The new parent of this node
  • index : Number
    The index it was moved to

nodedragover : ( Object dragOverEvent )

Fires when a tree node is being targeted for a drag drop, return false to signal drop not allowed. The dragOverEvent ...
Fires when a tree node is being targeted for a drag drop, return false to signal drop not allowed. The dragOverEvent passed to handlers has the following properties:
  • tree - The TreePanel
  • target - The node being targeted for the drop
  • data - The drag data from the drag source
  • point - The point of the drop - append, above or below
  • source - The drag source
  • rawEvent - Raw mouse event
  • dropNode - Drop node(s) provided by the source.
  • cancel - Set this to true to signal drop not allowed.
Listeners will be called with the following arguments:

dragOverEvent : Object

 

nodedrop : ( Object dropEvent )

Fires after a DD object is dropped on a node in this tree. The dropEvent passed to handlers has the following propert...
Fires after a DD object is dropped on a node in this tree. The dropEvent passed to handlers has the following properties:
  • tree - The TreePanel
  • target - The node being targeted for the drop
  • data - The drag data from the drag source
  • point - The point of the drop - append, above or below
  • source - The drag source
  • rawEvent - Raw mouse event
  • dropNode - Dropped node(s).
Listeners will be called with the following arguments:
  • dropEvent : Object

enddrag : ( Ext.tree.TreePanel this, Ext.tree.TreeNode node, event e )

Fires when a drag operation is complete
Fires when a drag operation is complete
Listeners will be called with the following arguments:
  • this : Ext.tree.TreePanel
  • node : Ext.tree.TreeNode
  • e : event
    The raw browser event

dragdrop : ( Ext.tree.TreePanel this, Ext.tree.TreeNode node, DD dd, event e )

Fires when a dragged node is dropped on a valid DD target
Fires when a dragged node is dropped on a valid DD target
Listeners will be called with the following arguments:
  • this : Ext.tree.TreePanel
  • node : Ext.tree.TreeNode
  • dd : DD
    The dd it was dropped on
  • e : event
    The raw browser event

以上几乎是Ext Tree提供的所有响应拖动操作的事件

Demo地址:http://www.faceye.com/xuser/,在线帮助

分享到:
评论
2 楼 释皇天 2010-09-19  
能不能发个源码,包括数据库。谢了我邮箱是:godisagirlnanyang@126.com
1 楼 demojava 2010-07-23  
能不能发个源码,谢了我邮箱是:fsmdemo@163.com

相关推荐

    EXT tree 使用 实例 最新

    在EXT Tree的使用实例中,我们通常会涉及到以下几个关键知识点: 1. **配置项与属性**:EXT Tree允许通过配置项定制其行为和外观。例如,`rootVisible` 控制是否显示根节点,`nodeType` 定义节点类型,`expanded` ...

    完成Ext 拖拽树后对新的树节点顺序进行保存

    5. **持久化存储**:最后,将更新后的树数据模型序列化并保存到服务器,以确保更改持久化。 在提供的DDTreeTaxis2压缩包中,很可能包含了实现以上逻辑的示例代码。代码可能包括一个ExtJS的树组件配置,以及处理拖放...

    ext TREE

    Tree组件是EXT JS中的一个重要部分,它允许开发者创建可交互的树形结构,通常用于展示层次关系的数据,如文件系统、组织结构或数据库层次结构。 【描述】虽然描述中提到的是"NULL",但我们可以根据EXT JS Tree组件...

    ext的tree两个拖拽例子

    本主题主要关注EXT的TreePanel中的拖放(Drag and Drop)功能,这是一项允许用户通过鼠标操作重新排序节点或在不同树之间移动节点的强大特性。下面我们将深入探讨这两个拖放例子。 首先,我们要理解EXT JS的拖放...

    Ext Tree示例

    Ext Tree 是 Ext JS 库中的一个组件,它用于在用户界面上展示层次化的数据结构,类似于文件系统的目录结构。在给定的资源中,我们有多个 HTML 文件(tree2.html, tres.html, s1.html, tree.html)和 JavaScript 文件...

    oa.rar_ext_ext java oa_ext oa_ext tree_java ext tree

    其中,“oa”可能是项目或系统的名称,而“ext”、“java”、“oa_ext”、“tree_java”和“ext_tree”则可能涉及到不同的模块或技术组件。描述中提到的“ext tree 与ssh2的结合,主要演示ext在ssh2中的使用”为我们...

    EXT Tree的简单实践

    EXT Tree 是一个基于 ExtJS 库的组件,用于构建可交互的树形数据结构。在 Web 开发中,树形控件常用于展示层级关系的数据,例如目录结构、组织架构或者菜单系统。EXT Tree 提供了丰富的功能和高度自定义的选项,使其...

    完成Ext tree 拖拽节点到 textfield 控件中

    以前有许多人需要将 tree 的节点拖拽到其他控件中的问题,前段时间已经解决了,现在也将它的源代码贡献上来。 这个树的数据是静态的,没有做动态的,而且树节点的拖拽也没有做过多的处理,如果要知道怎么样做树...

    ext grid tree 应用

    在这个例子中,开发者通过编写自定义代码,实现了从数据库动态读取数据并显示在Grid和Tree中,同时支持分页功能,极大地提高了用户体验。 1. **EXT Grid**: EXT Grid是EXT JS中的核心组件之一,用于展示大量数据。...

    Ext.net实现GridPanel拖动行、上移下移排序功能DEMO

    对于GridPanel中拖动选中行排序的实现,网上有不少ExtJs实现的例子,但是没有找到使用Ext.net实现的,正好最近有个需求要使用,干脆来写一个。 DEMO功能说明: 1、拖动GridPanel选中行到新位置排序。 2、在拖动结束...

    Ext tree json 动态加载完美实例

    在本文中,我们将深入探讨如何使用Ext JS的Tree Panel与JSON数据进行动态加载,并实现多选和单选功能。Ext JS是一种强大的JavaScript库,用于构建富客户端应用,而Tree Panel则是展示层次结构数据的一种组件。在后台...

    extTree例子点击出现等

    ExtTree是Ext JS库中的一个组件,用于创建和展示树形结构的数据。它在Web应用程序中广泛使用,特别是在需要组织和导航层次结构信息时。在本案例中,“extTree例子点击出现界面”指的是用户在浏览ExtTree时,通过点击...

    EXT TREE 扩展CHECKBOX JS

    这段代码告诉EXT JS,当我们加载树形数据时,每个节点都应使用`Ext.tree.TreeCheckNodeUI`来渲染,这样每个节点都会有一个与之关联的复选框。 `TreeCheckNodeUI`类提供了以下关键特性: 1. **复选框渲染**:在每个...

    Ext.tree.TreeLoader附带封装的json类

    在本文中,我们将深入探讨`Ext.tree.TreeLoader`与JSON数据在Ext JS框架中的应用。`Ext.tree.TreeLoader`是Ext JS库中的一个组件,它负责加载和解析树形结构的数据,而JSON(JavaScript Object Notation)则是一种轻...

    EXT tree学习 参考

    EXT JS是一个强大的JavaScript UI框架,提供了一系列的可复用组件,EXT Tree就是其中之一,它可以帮助开发者构建功能丰富的树形视图,常用于文件系统、组织结构、导航菜单等场景。 EXT Tree的核心特性包括: 1. **...

    Ext 带多选的Tree

    在EXT JS这个强大的JavaScript库中,Tree组件是一个用于展示层级数据的重要工具。"Ext 带多选的Tree"指的是在EXT JS的Tree组件中集成了多选功能,允许用户通过复选框来选择多个树节点,从而实现批量操作或者进行多级...

    ext-tree.rar_ext_ext tr_ext tre_ext.tr_ext.tree

    【标题】"ext-tree.rar_ext_ext tr_ext tre_ext.tr_ext.tree" 暗示这是一个关于Ext JS库中TreePanel组件的实例,其中可能包含了用于创建和管理数据结构的树形视图,以及与数据库交互的功能。 【描述】"ext的树的...

    ext tree grid 的高级实例运用

    总之,`ext tree grid`的高级实例运用展示了EXT JS的强大之处,它能够轻松地处理复杂的数据呈现和用户交互。通过熟练掌握这些技巧,开发者可以创建出更加动态、灵活且用户友好的Web应用。在实际项目中,这种结合使用...

    ext tree json 例子(不含EXT包)

    描述中提到的是EXT JS Tree的几个关键特性:拖动功能、动态加载JSON数据以及拖动后的事件处理。这些特性使得EXT JS Tree不仅具有美观的界面,还具有高度的交互性和灵活性。 首先,我们来看`extjs的tree的使用(拖动...

    ext tree 分页

    在EXT JS框架中,"ext tree 分页"是一种优化技术,用于处理大量数据时避免页面卡顿的问题。在EXT JS的树形组件(TreePanel)中,如果一次性加载所有节点,特别是当树结构非常深或者节点数量巨大时,不仅会消耗大量...

Global site tag (gtag.js) - Google Analytics