Extjs4.2 Tree使用技巧小结demo

本案例使用了Ext.Tree.Panel的如下知识点:

1.刷新、重新加载Tree,定位到上次的节点位置

2.Tree的右键操作

3.Extjs4.x Tree获取当前选中的节点

4.新增、修改、删除Tree节点

5.修改tree节点的属性,例如text,iconCls,leaf等

6.treedata rest proxy

7.treeStore.sync的同步回调方法

8.Extjs4.x Tree获取父节点,获取子节点Chirldrens

9.Extjs4.x TreePanel的展开,收缩

10.Extjs4.x Tree的拖拽操作treeviewdragdrop插件,响应类型有before,after,append

11.Extjs4.x Guid,UUID的生成

等等。

Demo视频:

源码共享:

/// <reference path="../../Ext.js" />
Ext.define("WMS.view.OrgTree", {
extend: 'Ext.tree.Panel',
alias: 'widget.OrgTree',
id: 'orgTreePanel',
width: 200,
region: 'west',
animate: true,
autoScroll: true,
rootVisible: true,
store: 'OrgTree',
loadMsg: true,
title: '组织架构',
iconCls: 'User',
border: false,
viewConfig: {
plugins: {
ptype: 'treeviewdragdrop',
appendOnly: false
}
},
collapsible: true,//是否可以折叠
split: true,
tools: [{
type: 'expand',
handler: function () {
Ext.getCmp("orgTreePanel").expandAll();
}
}, {
type: 'collapse',
handler: function () {
Ext.getCmp("orgTreePanel").collapseAll();
}
}]
}); /************************************/
//Controller
Ext.define('WMS.controller.Org', {
extend: 'Ext.app.Controller',
stores: ['OrgUser', 'OrgTree'],
models: ['OrgUser'],
views: ['OrgTb', 'OrgTree', 'OrgTreeContextMenu', 'OrgUserGrid'],
refs: [
{
ref: 'orgTree',
selector: 'OrgTree'
},
{
ref: 'orgUserGrid',
selector: 'OrgUserGrid'
},
{
ref: 'orgTreeContextMenu',
selector: 'OrgTreeContextMenu',
autoCreate: true,
xtype: 'OrgTreeContextMenu'
}
],
init: function () {
this.control({
'OrgTree': {
itemcontextmenu: this.ShowRightMenu,
itemclick: this.TreeNodeClick
},
'OrgTreeContextMenu': {
click: this.RightMenuClick
},
'OrgTree > treeview': {
drop: this.OrgDragDrop
},
'OrgUserGrid button[action=btnDelete]': {
click: function () {
alert("btnDelete 删除");
}
},
'OrgUserGrid button[action=btnReload]': {
click: function () {
alert("btnReload 刷新");
}
} });
},
//显示右键菜单
ShowRightMenu: function (view, record, item, index, event) {
event.preventDefault();
var menu = this.getOrgTreeContextMenu();
view.select();
menu.showAt(event.getXY());
},
//响应右键菜单单击
RightMenuClick: function (menu, item, event, opts) {
//获取选中的node
tree = this.getOrgTree();
selNode = tree.getSelectionModel().selected.items[0];
treeStore = this.getOrgTree().getView().getTreeStore();
console.log(item.iconCls);
switch (item.iconCls) {
case 'Reload':
idPath = selNode.getPath("id");
tree.getStore().load({
node: tree.getRootNode(),
callback: function () {
tree.expandPath(idPath, 'id');
}
});
break;
case 'ChartOrganisationAdd':
Ext.MessageBox.prompt("新增组织架构", "名称:", function (button, text) {
if (button == "ok") {
if (Ext.util.Format.trim(text) != "") {
//设置新增节点,如果本来就是子节点,那么设置子节点leaf为false
//console.log(Ext.data.IdGenerator.get('uuid').generate());
selNode.appendChild({
text: text,
leaf: true,
iconCls: 'Group',
id: Ext.data.IdGenerator.get('uuid').generate()
});
if (selNode.get("leaf")) {
selNode.set("leaf", false);
selNode.set("iconCls", "");
}
selNode.expand();
treeStore.sync();
}
}
});
break;
case 'ChartOrgInverted':
if (selNode.data.id == "00000000-0000-0000-0000-000000000000") {
Ext.Tools.Msg("根节点不允许修改!", 9);
return;
}
Ext.MessageBox.prompt("修改组织名称", "新名称:", function (button, text) {
if (button == "ok") {
if (Ext.util.Format.trim(text) != "") {
if (selNode.data.text != text) { /* 在修改值的情况下,请求处理 */
selNode.set("text", text);
treeStore.sync();
}
}
}
}, this, false, selNode.data.text);
break;
case 'ChartOrganisationDelete':
if (selNode.data.id == "00000000-0000-0000-0000-000000000000") {
Ext.Tools.Msg("根节点不允许删除!", 9);
return;
}
if (!selNode.data.leaf) {
Ext.Tools.Alert("警告", "系统仅支持您删除叶子节点!","E");
return;
}
Ext.MessageBox.confirm("警告", "是否要删除该“"+selNode.data.text+"”组织架构?请确认该组织下已无用户!", function (button, text) {
if (button == "yes") {
parentNode = selNode.parentNode;
nextSibling = selNode.nextSibling;
//console.log(selNode.getPath("id"));
selNode.remove();
if (parentNode.childNodes.length <= 0) {
parentNode.set("leaf", true);
parentNode.set("iconCls", "Group");
}
treeStore.sync({
success: function (batch, options) {
rst = Ext.JSON.decode(batch.operations[0].response.responseText);
if (rst.result != 0) {
parentNode.insertBefore(selNode, nextSibling);
tree.getSelectionModel().select(selNode);
}
}
});
}
});
break;
case 'UserAdd':
break;
case 'GroupAdd':
break;
case 'UserCross':
break;
case 'StatusInvisible':
break;
}
},
//树拖拽操作
OrgDragDrop:function (node, data, overModel, dropPosition, eOpts) {
Ext.Ajax.request({
url: '/Admin/Org/DragDrop',
method: 'POST',
params: {
movedId: data.records[0].getId(),
referenceId: overModel.getId(),
dropPosition: dropPosition
},
success: function (response) {
rst = Ext.JSON.decode(response.responseText);
Ext.Tools.Msg(rst.msg, rst.result);
},
failure: function (response) {
Ext.Tools.Msg('请求超时或网络故障,错误编号:' + response.status, 9);
}
});
},
//获取组织架构的用户
TreeNodeClick: function (view, record, item, index) {
var id = record.getId();
var Enode = view.getTreeStore().getNodeById(id);
var idArray = new Array();
if (id != "00000000-0000-0000-0000-000000000000") {
idArray.push(id);
this.GetChilds(idArray, Enode);
}
usrstore = this.getOrgUserStore();
usrstore.getProxy().setExtraParam("ids", idArray);
usrstore.load();
},
GetChilds: function (idArray, node) {
ts = this;
childnodes = node.childNodes;
Ext.each(childnodes, function () {
var nd = this;
idArray.push(nd.getId());
if (nd.hasChildNodes()) {
ts.GetChilds(idArray, nd);
}
});
}
});

Extjs4.2 Tree使用技巧的更多相关文章

  1. Extjs4.2 Tree使用技巧小结demo

    本案例使用了Ext.Tree.Panel的如下知识点: 1.刷新.重新加载Tree,定位到上次的节点位置 2.Tree的右键操作 3.Extjs4.x Tree获取当前选中的节点 4.新增.修改.删除 ...

  2. Extjs4.x Tree树刷新,默认选中展开到最后一次选中的节点

    跟Extjs3.0不同Extjs4.2的写法如下: idPath = selNode.getPath("id"); tree.getStore().load({ node: tre ...

  3. HDU 5416 CRB and Tree (技巧)

    题意:给一棵n个节点的树(无向边),有q个询问,每个询问有一个值s,问有多少点对(u,v)的xor和为s? 注意:(u,v)和(v,u)只算一次.而且u=v也是合法的. 思路:任意点对之间的路径肯定经 ...

  4. ExtJs4之TreePanel

    Tree介绍 树形结构,是程序开发,不可缺少的组件之一.ExtJs中的树,功能强大美观实用.功能齐全,拖拉,排序,异步加载等等. 在ExtJs4中Tree和Grid具有相同的父类,因此Grid具有的特 ...

  5. ExtJS 4 树

    Tree Panel是ExtJS中最多能的组件之一,它非常适合用于展示分层的数据.Tree Panel和Grid Panel继承自相同的基类,所以所有从Grid Panel能获得到的特性.扩展.插件等 ...

  6. AC 自动机学习笔记

    虽然 NOIp 原地爆炸了,目前进入 AFO 状态,但感觉省选还是要冲一把,所以现在又来开始颓字符串辣 首先先复习一个很早很早就学过但忘记的算法--自动 AC AC自动机. AC 自动机能够在 \(\ ...

  7. Extjs4中的常用组件:Grid、Tree和Form

    至此我们已经学习了Data包和布局等API.下面我们来学习作为Extjs框架中我们用得最多的用来展现数据的Grid.Tree和Form吧! 目录: 5.1. Grid panel 5.1.1. Col ...

  8. Extjs4.x Ext.tree.Panel 过滤Filter以及trigger field的使用

    Extjs4.x中已经取消了组件Ext.Tree.TreeFilter功能,却掉了树形结构的过滤功能,要实现该功能只能自己写了. Tree节点筛选UI很简单,一个Tbar,一个trigger即可解决问 ...

  9. Maven类包冲突终极三大解决技巧 mvn dependency:tree

    Maven对于新手来说是<步步惊心>,因为它包罗万象,博大精深,因为当你初来乍到时,你就像一个进入森林的陌生访客一样迷茫. Maven对于老手来说是<真爱配方>,因为它无所不能 ...

随机推荐

  1. [Unity3D]Unity3D游戏开发之刀光剑影特效的实现

    大家好,我是秦元培,欢迎大家关注我的博客,我的博客地址是blog.csdn.net/qinyuanpei. 我实在不明确有的人为什么不喜欢武侠/仙侠类游戏,也许是因为武侠/仙侠类游戏身上被永远烙上的国 ...

  2. 判断文件是否存在,不存在创建文件&&判断文件夹是否存在,不存在创建文件夹

    1.判断文件是否存在,不存在创建文件 File file=new File("C:\\Users\\QPING\\Desktop\\JavaScript\\2.htm"); if( ...

  3. 查看oracle数据库服务器的名字

    原文:查看oracle数据库服务器的名字 windows 中 1. select name from v$database ; 直接运行就可以查看了, 2.查看tnsnames.ora 的连接,有个S ...

  4. Hybrid

    “榕树下·那年”移动app ( hybrid ) 开发总结   榕树下网站本身的技术人员并不多,所以app开发的任务就到了母公司盛大文学这边.       盛大文学无线业务中心负责这次具体开发任务. ...

  5. [翻译]MEAN.IO与MEAN.JS的前世今生

    写在前面: 因为项目要求要学习mean,所以要从搭建环境开始,网上的教程不怎么多,但是感觉方法倒是不少,也没多想,就开始安装,运行起来发现怎么和安装教程中的目录结构不同? 想了好久,也翻看目录半天,总 ...

  6. selenium2入门 用selenium安装、加载、启用插件(一)

    一:下载 下载地址是:http://docs.seleniumhq.org/download/

  7. [译]JVM运行时数据区

    (本篇文章翻译自JVM Run-Time Data Areas) 这是我阅读JVM规范的笔记,而且我画了一个图来帮助我理解. 1.每一个单独的线程(非共享的)的数据区 针对每一个单独的线程的数据区包括 ...

  8. 大约ActionContext.getContext()使用体验

    这是我在另一个人的博客看了,原来博客的时间长一点.我把它简化了一下,运营商,以方便它看起来. 为了避免与Servlet API耦合在一起,方便Action类做单元測试,Struts 2对HttpSer ...

  9. wcf契约版本处理与异常处理(随记)

    -----------版本控制策略:必须支持向后兼容:----就是当服务端发生改变,但客户端未更新会不会发生错误: 一旦契约发布,若要契约发生变化,如何不影响客户端使用: ----wsdl:契约: 服 ...

  10. 应用CSS的page-break-after属性 实现WEB页面强制分页打印

    虽然dedecms.com向大家介绍了很多CSS属性的相关知识,但有些非常冷门的属性还是有所欠缺.在B/S程序中,对打印页面的控制,CSS相对比较弱,例如: 自动分页, 就基本没啥实际用途.我们通常需 ...