//实现grid拖拽
Ext.onReady(function(){
var dragRec = Ext.data.Record.create([
{name: 'name'},
{name: 'age'},
{name: 'kind'}
]);
var dragReader = new Ext.data.ArrayReader({
// id: 0 // 提供数组的下标位置存放记录的ID(可选的) // The subscript within row Array that provides an ID for the Record (optional)
}, dragRec);
var dropRec = Ext.data.Record.create([
{name: 'name'},
{name: 'age'},
{name: 'kind'}
]);
var dropReader = new Ext.data.ArrayReader({
// id: 0 // 提供数组的下标位置存放记录的ID(可选的) // The subscript within row Array that provides an ID for the Record (optional)
}, dropRec);
var dragStore = new Ext.data.GroupingStore({
reader:dragReader,
sortInfo:{field: 'age', direction: "ASC"},//必须要有
groupField:'kind',
data:[['张三',20,'a'],['李四',30,'a'],['王柳',18,'b'],
['王丹丹',30,'b'],['张鼎鼎',28,'c']
]
});
var dropStore = new Ext.data.GroupingStore({
reader:dropReader,
sortInfo:{field: 'age', direction: "ASC"},//必须要有
groupField:'kind',
data:[]
});
var dragGrid = new Ext.grid.GridPanel({
store: dragStore,
columns: [
{ header: "姓名", width: 100, sortable: true, dataIndex: 'name'},
{header: "年龄", width: 80, sortable: true, dataIndex: 'age'},
{header: "类别", width: 80, sortable: true, dataIndex: 'kind'}
],
margins : '3 3 3 3',
enableDragDrop :true,
ddGroup : 'dragGridDDGroup',
viewConfig: {
// forceFit: true
},
view: new Ext.grid.GroupingView({
forceFit : true,
startCollapsed:false,//分组是关闭的
hideGroupedColumn:true,//隐藏分组列
groupTextTpl : '{text} ({[values.rs.length]} 条记录)'
}),
sm: new Ext.grid.RowSelectionModel({singleSelect:false}),
// width:400,
flex:1,
height:300,
frame:true,
title:'选择'
});
var dropGrid = new Ext.grid.GridPanel({
store: dropStore,
columns: [
{ header: "姓名", width: 100, sortable: true, dataIndex: 'name'},
{header: "年龄", width: 80, sortable: true, dataIndex: 'age'},
{header: "类别", width: 80, sortable: true, dataIndex: 'kind'}
],
margins : '3 3 3 3',
enableDragDrop :true,
ddGroup : 'dropGridDDGroup',
viewConfig: {
// forceFit: true
},
view: new Ext.grid.GroupingView({
forceFit : true,
startCollapsed:false,//分组是关闭的
hideGroupedColumn:true,//隐藏分组列
groupTextTpl : '{text} ({[values.rs.length]} 条记录)'
}),
sm: new Ext.grid.RowSelectionModel({singleSelect:false}),
//width:400,
flex:1,
height:300,
frame:true,
title:'已选'
});
var panel = new Ext.Panel({
layout:'hbox',
border:false,
width:1000,
height:350,
renderTo:Ext.getBody(),
items:[dragGrid,dropGrid],
buttons : [{
text:'复位',
handler:function(){
alert('arrNewId:'+arrNewId+'</br>arrDelId:'+arrDelId)
}
}]
});
var dropGridDropTargetEl = dropGrid.getView().el.dom.childNodes[0].childNodes[1];
var dropGridDropTarget = new Ext.dd.DropTarget(
dropGridDropTargetEl, {
ddGroup : 'dragGridDDGroup',
copy : true,
notifyDrop : function(ddSource, e, data) {
function addRow(record, index, allItems) {
dropGrid.getStore().addSorted(record);//addSorted排序添加
ddSource.grid.store.remove(record);
}
// Loop through the selections
Ext.each(ddSource.dragData.selections, addRow);
dropGrid.getView().refresh();
ddSource.grid.getView().refresh();
return (true);
}
});
var dragGridDropTargetEl = dragGrid.getView().el.dom.childNodes[0].childNodes[1];
var dragGridDropTarget = new Ext.dd.DropTarget(
dragGridDropTargetEl, {
ddGroup : 'dropGridDDGroup',
copy : false,
notifyDrop : function(ddSource, e, data) {
function addRow(record, index, allItems) {
dragGrid.getStore().addSorted(record);
ddSource.grid.store.remove(record);
}
Ext.each(ddSource.dragData.selections, addRow);
dropGrid.getView().refresh();
ddSource.grid.getView().refresh();
return (true);
}
});
});
- 大小: 47.8 KB
分享到:
相关推荐
这个"ExtJS3.1-3.3中文API文档.zip"包含了从3.1版本到3.3版本的中文API文档,是学习和开发基于ExtJS应用的重要参考资料。 中文API文档通常包含以下几个主要部分: 1. **基础类库**:这部分介绍Ext的基础类,如...
这个压缩包中的源代码实例涵盖了以上所有知识点,通过查看和学习这些示例,开发者可以深入理解ExtJs 3.1的功能,并快速上手实践。对于任何想要掌握ExtJs的人来说,这是一份不可多得的学习材料。
拖放(Drag and Drop)是一种直观的用户交互方式,ExtJS的小部件(Widget)提供了实现这一功能的机制,允许用户通过拖动对象来完成各种操作,如重新排序列表项或移动组件位置。 ### 4. 构建可配置的复合组件 书中还...
2.2. 让我们搞一个grid出来耍耍吧。 2.3. 上边那个是1.x的,2.0稍微有些不同哦 2.4. 按顺序,咱们先要把常见功能讲到,让grid支持按列排序 2.5. 让单元格里显示红色的字,图片,按钮,你还能想到什么? 2.6. ...
通过上述步骤,我们可以使用ExtJS轻松地实现一个功能齐全的动态树形结构。这种结构不仅美观大方,而且能够高效地处理大量分层数据,非常适合于文件管理系统等场景。希望本教程能帮助您更好地理解和掌握ExtJS中的树形...
-修正extjs最新版本(v3.2.2)中的一个bug,如果下拉列表中存在两个相同的Text,则SelectedValue返回值永远是第一个Text的值(feedback:ben.zhou)。 -应用补丁#6593, #6621(feedback:vbelyaev)。 +修正IE7下Grid分页...
2.2. 让我们搞一个grid出来耍耍吧。 2.3. 上边那个是1.x的,2.0稍微有些不同哦 2.4. 按顺序,咱们先要把常见功能讲到 2.4.1. 自主决定每列的宽度 2.4.2. 让grid支持按列排序 2.5. 让单元格里显示红色的字,图片,...
Ex4.0共2个压缩包特性,《ext js权威指南》 前 言 第1章 ext js 4开发入门 / 1 1.1 学习ext js必需的基础知识 / 1 1.2 json概述 / 3 ...10.3.5 分组功能:ext.grid.featrue.grouping / 543 10.3.6 分组汇总...
9.6. JsonView实现用户卡片拖拽与右键菜单 9.7. 下拉列表选择每页显示多少数据 10. 撕裂吧!邪魔外道与边缘学科。 10.1. dwr与ext整合 10.1.1. 无侵入式整合dwr和ext 10.1.2. DWRProxy 10.1.3. DWRTreeLoader 10.1.4...
在这个示例中,`TreePanel` 包含了一个根节点,根节点下面有两个文件夹和一个文件。`TreeLoader` 负责从服务器加载数据。 ##### 5.2 事件处理 `TreePanel` 支持多种事件处理,例如节点展开、折叠、点击等。这些...