对EXTJS的控件之间DD的相关总结(一)
来源:互联网 发布:新疆网络蛋糕 编辑:程序博客网 时间:2024/05/17 01:10
近来由于项目用到EXT,觉得里面的DD用起来很有意思,研究了一段时间源码,也总结了一些常用控件之间的用法,这方面网上的资料比较少,当时自己也走了一些弯路,现在暂时总结一下
ext提供的Tree和Grid本身就有拖拽的功能,使用过TreePanel或者GridPanel的人都知道,对于要想让tree可以拖拽,那么必须为tree的enableDD属性设置为true。
1,tree到grid
panel.dropZone = new Ext.dd.DropZone(panel.getEl(), {ddGroup:"SendTreeDDGroup", dropNotAllowed:"x-dd-drop-delete", getTargetFromEvent:function (e) {
return e.getTarget("");
}, onNodeOver:function (nodedate, dragsource, e, data) {
if (!data.node) {
if (data.personData.name) {
// 显示"nodrop"图标
return "x-dd-drop-nodrop";
} else {
if (data.personData.html) {
// 显示删除图标
}
}
return this.dropNotAllowed;
}
if (data.node.attributes.leaf && SendGrid.store.findBy(function (record, id) {
return id == data.node.id;
}) == -1) {
return "x-dd-drop-ok-add";
} else {
return "x-dd-drop-nodrop";
}
return this.dropNotAllowed;
}, onNodeDrop:function (nodedate, dragsource, e, data) {
if (data.node.attributes.leaf == true) {
SendGrid.store.add(new Ext.data.Record({dept:data.node.attributes.dept, faxnum:data.node.attributes.faxnum, faxtype:data.node.parentNode.attributes.dept, faxtel:data.node.attributes.faxnum}, data.node.id));
}
return false;
}});
2,grid到tree的例子
beforenodedrop: function(dropEvent) {
var node = dropEvent.target; // 目标结点
var data = dropEvent.data; // 拖拽的数据
var point = dropEvent.point; // 拖拽到目标结点的位置
// 如果data.node为空,则不是tree本身的拖拽,而是从grid到tree的拖拽,需要处理
if(!data.node) {
switch(point) {
case 'append':
// 添加时,目标结点为node,子结点设为空
ddFn(node, null, data.selections);
break;
case 'above':
// 插入到node之上,目标结点为node的parentNode,子结点为node
ddFn(node.parentNode, node, data.selections);
break;
case 'below':
// 插入到node之下,目标结点为node的parentNode,子结点为node的nextSibling
ddFn(node.parentNode, node.nextSibling, data.selections);
break;
}
}
其中ddFn方法如下
var ddFn= function(node, refNode, selections) {
for(var i = 0; i < selections.length; i ++) {
var record = selections[i];
node.insertBefore(new Tree.TreeNode({
text: record.get('text'),
id: record.get('id'),
leaf: record.get('leaf'),
cls: record.get('cls')
}), refNode);
}
}
当然ddFn里面要根据需要判断是否有重复id等,有重复则不再drop
- 对EXTJS的控件之间DD的相关总结(一)
- dd fdisk mount相关命令的总结
- extjs的相关属性
- Extjs常用的控件
- 对ExtJs的态度
- 对Extjs一类前端技术的分析思维总结
- Extjs实战(Extjs+Spring+Hibernate+dwr)章二:控件的组件化(一)
- 对Java Generic相关知识的总结
- extjs的总结
- extjs mvc的总结
- ExtJs学习相关的资源
- extjs CheckTree 的相关应用
- C# 对DataGridView控件的操作总结
- 对控件响应事件的写法总结
- EXTJS 常用控件的使用
- EXTJS 常用控件的使用
- ExtJS 控件的基础 Panel
- ExtJs 一些常用的控件
- php调试器xdebug的安装
- 写在2009
- linkers and loaders,complier,以及一些杂感。
- MFC bmp图片处理
- 关于需求分析(总结)
- 对EXTJS的控件之间DD的相关总结(一)
- 看英文书
- 社会经济实验室
- const 在C++中的用法
- JPS问题
- my favorite
- 一个看似简单的问题(#if与#ifdef的区别)
- 也说一两句
- mingw & msys (zz)