Ext4.2的Ext.grid.plugin.RowExpander無法觸發(fā)事件解決辦法
Ext4.2+ Ext.grid.plugin.RowExpander存在bug,添加的collapsebody,expandbody無法觸發(fā),查看了下 Ext.grid.plugin.RowExpander對(duì)應(yīng)的源代碼,沒有添加collapsebody,expandbody事件,即使按照網(wǎng)上的方 法重寫Ext.grid.plugin.RowExpander的init和toggleRow方法也無法觸發(fā) collapsebody,expandbody事件。
解決辦法:給grid對(duì)象添加collapsebody,expandbody事件,然后給grid配置這2個(gè)事件,同時(shí)重寫Ext.grid.plugin.RowExpander的toggleRow方法,觸發(fā)grid添加的這2個(gè)事件即可。
測(cè)試源代碼如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <title>Ext4.2+ Ext.grid.plugin.RowExpander無法觸發(fā)collapsebody,expandbody事件解決辦法</title> <link rel="stylesheet" type="text/css" href="../../resources/css/ext-all.css" rel="external nofollow" /> <script type="text/javascript" src="../../ext-all-debug.js"> </script> <script> Ext.override(Ext.grid.plugin.RowExpander, { // Override to fire collapsebody & expandbody init: function(grid) { this.callParent(arguments); // grid.getView().addEvents('collapsebody', 'expandbody');//ext論壇找到的解決辦法,這樣也無法添加事件 //存儲(chǔ)grid對(duì)象 this.grid=grid this.grid.addEvents('collapsebody', 'expandbody');//給grid對(duì)象添加事件 }, toggleRow: function(rowIdx, record) { var me = this, view = me.view, rowNode = view.getNode(rowIdx), row = Ext.fly(rowNode, '_rowExpander'), nextBd = row.down(me.rowBodyTrSelector, true), isCollapsed = row.hasCls(me.rowCollapsedCls), addOrRemoveCls = isCollapsed ? 'removeCls' : 'addCls', ownerLock, rowHeight, fireView; // Suspend layouts because of possible TWO views having their height change Ext.suspendLayouts(); row[addOrRemoveCls](me.rowCollapsedCls); Ext.fly(nextBd)[addOrRemoveCls](me.rowBodyHiddenCls); me.recordsExpanded[record.internalId] = isCollapsed; view.refreshSize(); // Sync the height and class of the row on the locked side if (me.grid.ownerLockable) { ownerLock = me.grid.ownerLockable; // fireView = ownerLock.getView(); view = ownerLock.lockedGrid.view; fireView=ownerLock.lockedGrid.view; rowHeight = row.getHeight(); // EXTJSIV-9848: in Firefox the offsetHeight of a row may not match // it is actual rendered height due to sub-pixel rounding errors. To ensure // the rows heights on both sides of the grid are the same, we have to set // them both. row.setHeight(isCollapsed ? rowHeight : ''); row = Ext.fly(view.getNode(rowIdx), '_rowExpander'); row.setHeight(isCollapsed ? rowHeight : ''); row[addOrRemoveCls](me.rowCollapsedCls); view.refreshSize(); } else { fireView = view; } //通過grid觸發(fā)事件,而不是view this.grid.fireEvent(isCollapsed ? 'expandbody' : 'collapsebody', row.dom, record, nextBd); //下面為ext論壇的解決辦法,無效 //fireView.fireEvent(isCollapsed ? 'expandbody' : 'collapsebody', row.dom, record, nextBd); // Coalesce laying out due to view size changes Ext.resumeLayouts(true); }, }); //Ext.loader.setConfig({enabled:true}); Ext.onReady(function() { Ext.QuickTips.init(); var store = new Ext.data.Store({ fields:[ {name:'fileName',type:'string'}, {name:'room',type:'string'}, {name:'recordDate',type:'string'}, ], data:[ {fileName:'文件1',room:'會(huì)議室1',recordDate:'2014-07-03'}, {fileName:'文件2',room:'會(huì)議室2',recordDate:'2014-07-03'}, {fileName:'文件3',room:'會(huì)議室3',recordDate:'2014-07-03'} ], autoLoad:true }); var expander = new Ext.grid.plugin.RowExpander({ rowBodyTpl:new Ext.XTemplate('<div class="detailData">pp</div>'), listeners:{ expandbody:function(){//無法觸發(fā)這個(gè)是事件 console.log('Ext.grid.plugin.RowExpander'); } } }); Ext.create('Ext.grid.Panel',{ xtype: 'row-expander-grid', store: store, listeners:{ expandbody:function(){//OK,可以觸發(fā) console.log('fired from grid'); } }, renderTo:Ext.getBody(), columns: [ {text: "文件名稱", flex: 1, dataIndex: 'fileName'}, {text: "會(huì)議室", dataIndex: 'room'}, {text: "錄制日期", renderer: Ext.util.Format.dateRenderer('Y-m-d'), dataIndex: 'recordDate'} ], width: 600, height: 300, plugins:expander, collapsible: true, animCollapse: false, title: 'Expander Rows in a Collapsible Grid', iconCls: 'icon-grid' }); }); </script> </head> <body id="docbody"> </body> </html>
相關(guān)文章
Ext JS 4實(shí)現(xiàn)帶week(星期)的日期選擇控件(實(shí)戰(zhàn)二)
Javascript 有提供Date 對(duì)象用于處理時(shí)間。但是Date 并沒有提供獲取星期的方法,jquery 的擴(kuò)展組件 等有直接提供這樣的一些現(xiàn)成包,感興趣的朋友可以了解下2013-08-08Extjs407 getValue()和getRawValue()區(qū)別介紹
mydate.getvalue() 返回的是對(duì)象;mydate.getRawValue() 返回的是該控件的顯示值,不知道的朋友可以參考下哈2013-05-05Extjs在exlipse中設(shè)置自動(dòng)提示的方法
spket最好用了,而且它還支持ext,安裝起來很簡(jiǎn)單.....2010-04-04extjs ColumnChart設(shè)置不同的顏色實(shí)現(xiàn)代碼
extjs為ColumnChart設(shè)置不同的顏色想必有很多朋友還是比較陌生的吧,接下來為大家詳細(xì)介紹下具體設(shè)置代碼,感興趣的朋友可以參考下哈2013-05-05Extjs 4.x 得到form CheckBox 復(fù)選框的值
CheckBox(復(fù)選框)主要用來接收用戶選擇的選項(xiàng),那么如何通過Extjs 4.x 得到form CheckBox的值呢?下面有個(gè)不錯(cuò)的方法,大家值得一看2014-05-05