`
zw122035828
  • 浏览: 5745 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

extjs3.1实现两个分组grid拖拽功能

 
阅读更多


//实现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

    这个"ExtJS3.1-3.3中文API文档.zip"包含了从3.1版本到3.3版本的中文API文档,是学习和开发基于ExtJS应用的重要参考资料。 中文API文档通常包含以下几个主要部分: 1. **基础类库**:这部分介绍Ext的基础类,如...

    ExtJs3.1目前所有例子源代码

    这个压缩包中的源代码实例涵盖了以上所有知识点,通过查看和学习这些示例,开发者可以深入理解ExtJs 3.1的功能,并快速上手实践。对于任何想要掌握ExtJs的人来说,这是一份不可多得的学习材料。

    extjs in action

    拖放(Drag and Drop)是一种直观的用户交互方式,ExtJS的小部件(Widget)提供了实现这一功能的机制,允许用户通过拖动对象来完成各种操作,如重新排序列表项或移动组件位置。 ### 4. 构建可配置的复合组件 书中还...

    掏钱学Ext(完整版) 附全部源码

    2.2. 让我们搞一个grid出来耍耍吧。 2.3. 上边那个是1.x的,2.0稍微有些不同哦 2.4. 按顺序,咱们先要把常见功能讲到,让grid支持按列排序 2.5. 让单元格里显示红色的字,图片,按钮,你还能想到什么? 2.6. ...

    ext实现动态树

    通过上述步骤,我们可以使用ExtJS轻松地实现一个功能齐全的动态树形结构。这种结构不仅美观大方,而且能够高效地处理大量分层数据,非常适合于文件管理系统等场景。希望本教程能帮助您更好地理解和掌握ExtJS中的树形...

    ExtAspNet_v2.3.2_dll

    -修正extjs最新版本(v3.2.2)中的一个bug,如果下拉列表中存在两个相同的Text,则SelectedValue返回值永远是第一个Text的值(feedback:ben.zhou)。 -应用补丁#6593, #6621(feedback:vbelyaev)。 +修正IE7下Grid分页...

    EXT2.0中文教程

    2.2. 让我们搞一个grid出来耍耍吧。 2.3. 上边那个是1.x的,2.0稍微有些不同哦 2.4. 按顺序,咱们先要把常见功能讲到 2.4.1. 自主决定每列的宽度 2.4.2. 让grid支持按列排序 2.5. 让单元格里显示红色的字,图片,...

    Ext Js权威指南(.zip.001

    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 分组汇总...

    Ext 开发指南 学习资料

    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...

    Ext表格控件和树控件

    在这个示例中,`TreePanel` 包含了一个根节点,根节点下面有两个文件夹和一个文件。`TreeLoader` 负责从服务器加载数据。 ##### 5.2 事件处理 `TreePanel` 支持多种事件处理,例如节点展开、折叠、点击等。这些...

Global site tag (gtag.js) - Google Analytics