001.
002.
003.
004.
005.
006.
007.
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的tree两个拖拽例子,话不多说,详见代码
EXT tree 使用 实例 最新 EXT使用实例,很漂亮。
以前有许多人需要将 tree 的节点拖拽到其他控件中的问题,前段时间已经解决了,现在也将它的源代码贡献上来。 这个树的数据是静态的,没有做动态的,而且树节点的拖拽也没有做过多的处理,如果要知道怎么样做树...
对于GridPanel中拖动选中行排序的实现,网上有不少ExtJs实现的例子,但是没有找到使用Ext.net实现的,正好最近有个需求要使用,干脆来写一个。 DEMO功能说明: 1、拖动GridPanel选中行到新位置排序。 2、在拖动结束...
自己编写的EXT例子,grid、tree从数据库读取数据动态显示,并进行分页。可以动态更换主题,并存入cookies中。
一个不错Ext Tree 自己去下个EXT2.0库吧
用ext + xml文件 完成 ext tree panel 树结构。延迟加载,支持 多选 单选。前后台数据交互使用的是 json串,挺不错的
EXT TREE 扩展CHECKBOX所需JS loader方法中添加: baseAttrs: {uiProvider: Ext.tree.TreeCheckNodeUI }
一个关于extTree的应用,点击会弹出界面啊,等等
ext tree 与ssh2的结合,主要演示ext在ssh2中的使用
NULL 博文链接:https://scmky.iteye.com/blog/1174740
关于Ext Tree Panel,相关的知识文档
Ext 带多选框的Tree
Ext分页排序 Ext分页排序 Ext分页排序
EXT支持GRID中文排序 主要是重写排序的方法
ext tree json 例子(不含EXT包)
ext 与数据库交互实例 ext 与数据库交互实例 ext 与数据库交互实例
Ext-tree加载Ext-tree加载Ext-tree加载Ext-tree加载Ext-tree加载Ext-tree加载Ext-tree加载Ext-tree加载Ext-tree加载Ext-tree加载Ext-tree加载Ext-tree加载Ext-tree加载
Ext tree 实现的是一棵异步加载的Tree,完整Demo项目,导入Eclipse就可以运行
在extjs中加载大量树节点时会卡死,用于解决大量数据加载。