基于ExtJs在頁面上window再調(diào)用Window的事件處理方法
今天在開發(fā)Ext的過程中遇到了一個惡心的問題,就是在ext.window頁面,點(diǎn)擊再次彈出window時,gridpanel中的store數(shù)據(jù)加載異常,不能正常被加載,會出現(xiàn)緩存,出現(xiàn)該問題,是因?yàn)閣indow窗口彈出時,兩個window同時存在,并且在兩個window交替使用時,需要先將一個窗口關(guān)閉,關(guān)閉時,會對window的緩存進(jìn)行清理,這樣就能保證store數(shù)據(jù)的正確加載。分享給大家,供參考。
var actInfoWindow2; function showCallFlowInfoWindow(flowid, actId) { var actWindowHeight1 = window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight; if(null != upldWin && undefined != upldWin && "" != upldWin){ upldWin.close(); } // 異?;顒幽P? Ext.define('callFlowModel', { extend: 'Ext.data.Model', fields: [{name: 'instance', type: 'string'}, {name: 'flowName', type: 'string'}, {name: 'prjName', type: 'string'}, {name: 'startTime', type: 'String'}] }); callFlowStore = Ext.create('Ext.data.Store', { autoLoad : true, model : 'callFlowModel', proxy : { type : 'ajax', url : 'subflow.do', reader : { type : 'json', root : 'callFlowList', totalProperty : 'total' } }, listeners: { 'beforeload': function (store, op, options) { var params = { //參數(shù) flowId : flowid, id : actId }; Ext.apply(store.proxy.extraParams, params); } } }); // 綁定數(shù)據(jù)模型flowColumns var callFlowColumns = [ { text: '實(shí)例名', dataIndex: 'instance', width:174 }, { text: '工程名', dataIndex: 'prjName',width: 174 }, { text: '工作流名', dataIndex: 'flowName',width: 174 }, { text: '啟動時間', dataIndex: 'startTime',width: 174 } ]; callFlowGrid = Ext.create('Ext.grid.Panel', { region : 'center', //tbar:querybar, id:'callFlowList', autoScroll : false, border:false, //columnLines : true, //selModel:selModel, //bbar : pageBar, columns : callFlowColumns, store : callFlowStore, loadMask : { msg : " 數(shù)據(jù)加載中,請稍等 " } }); if (actInfoWindow2 == undefined || !actInfoWindow2.isVisible()) { actInfoWindow2 = Ext.create('Ext.window.Window', { id : 'actInfoWindow2', title : '活動信息詳情', modal : true, closeAction : 'destroy', constrain : true, autoScroll : true, width : 700, height : actWindowHeight1 - 300, items : [ callFlowGrid ], listeners:{ beforeclose:function(){ actInfoWindow2.destroy(); } } }); } actInfoWindow2.show(); } if(null != upldWin && undefined != upldWin && "" != upldWin){ upldWin.close(); }
我的問題出現(xiàn)就是因?yàn)闆]有添加上面黃色背景的代碼片段導(dǎo)致的錯誤。供大家參考。兩個window交替使用時,需要交替關(guān)閉,這樣才能保證頁面的正常。ExtJs不建議彈出多window同時使用,當(dāng)然,如果能解決好ExtJs之間的數(shù)據(jù)交互,也未必不可以。
以上這篇基于ExtJs在頁面上window再調(diào)用Window的事件處理方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Extjs中通過Tree加載右側(cè)TabPanel具體實(shí)現(xiàn)
用Extjs4.1來做界面,有關(guān)Extjs4.1資料在網(wǎng)上也相對來說較少,下面是具體的實(shí)現(xiàn)代碼1.左側(cè)的功能樹2.需要打開的對應(yīng)的view,有類似需求的朋友可以參考下哈2013-05-05解決Extjs4中form表單提交后無法進(jìn)入success函數(shù)問題
form表單提交后無法進(jìn)入success函數(shù)的問題,很是常見,下面有個不錯的解決方法,感興趣的朋友可以參考下2013-11-11Extjs優(yōu)化(一)刪除冗余代碼提高運(yùn)行速度
Extjs 本身是一個加載慢的JS框架,這次來寫寫怎么減少冗余代碼,也是提高運(yùn)行速度,感興趣的朋友可以參考下哈,希望可以幫助到你2013-04-04常用Extjs工具:Extjs.util.Format使用方法
常用Extjs工具:Extjs.util.Format使用方法,需要的朋友可以參考下2012-03-03extjs表格文本啟用選擇復(fù)制功能具體實(shí)現(xiàn)
extjs提供了方便的表格組件grid供使用,但是默認(rèn)情況下表格中的文本是不能被選中的,自然也是無法復(fù)制的,下面就為大家介紹下選擇復(fù)制功能如何啟用,感興趣的朋友可以了解下2013-10-10關(guān)于viewport,Ext.panel和Ext.form.panel的關(guān)系
那個深入淺出ext作者比我還懶 viewport存放Ext.panel對象,其容器中的成員可以以borderlayout方式布局2009-05-05