EXTJS內(nèi)使用ACTIVEX控件引起崩潰問題的解決方法_extjs
來源:懂視網(wǎng)
責(zé)編:小采
時(shí)間:2020-11-27 20:48:17
EXTJS內(nèi)使用ACTIVEX控件引起崩潰問題的解決方法_extjs
EXTJS內(nèi)使用ACTIVEX控件引起崩潰問題的解決方法_extjs:問題 在本人目前的項(xiàng)目中,前端部分完全使用EXTJS基于One-Page理念搭建。除了一個(gè)HTML作為基本容器外,就全是JS文件了(頁面是由JS文件實(shí)現(xiàn)的)。當(dāng)用戶切換頁面時(shí)候,我們通過析構(gòu)上一個(gè)頁面對(duì)象,然后創(chuàng)建新頁面對(duì)象并展現(xiàn)在HTML中。基于這種架構(gòu),我們
導(dǎo)讀EXTJS內(nèi)使用ACTIVEX控件引起崩潰問題的解決方法_extjs:問題 在本人目前的項(xiàng)目中,前端部分完全使用EXTJS基于One-Page理念搭建。除了一個(gè)HTML作為基本容器外,就全是JS文件了(頁面是由JS文件實(shí)現(xiàn)的)。當(dāng)用戶切換頁面時(shí)候,我們通過析構(gòu)上一個(gè)頁面對(duì)象,然后創(chuàng)建新頁面對(duì)象并展現(xiàn)在HTML中。基于這種架構(gòu),我們

問題
在本人目前的項(xiàng)目中,前端部分完全使用EXTJS基于“One-Page”理念搭建。除了一個(gè)HTML作為基本容器外,就全是JS文件了(頁面是由JS文件實(shí)現(xiàn)的)。當(dāng)用戶切換頁面時(shí)候,我們通過析構(gòu)上一個(gè)頁面對(duì)象,然后創(chuàng)建新頁面對(duì)象并展現(xiàn)在HTML中。基于這種架構(gòu),我們還引入了一個(gè)ActiveX控件,用于展現(xiàn)報(bào)表。這一引入,問題就出來了:只要是訪問有報(bào)表控件存在的頁面,用戶切換2次頁面,IE就會(huì)崩潰(FF無此問題),百試不爽。
原因
因?yàn)橄到y(tǒng)設(shè)計(jì)時(shí)考慮到了資源釋放,專門處理過析構(gòu)部分,而且無ActiveX的頁面不存在問題。故問題肯定是出在IE對(duì)包含在JS中的ActiveX控件釋放出了問題。畢竟在傳統(tǒng)的以HTML或JSP、PHP頁搭建的前端中,ActiveX是屬于頁面的,只要用戶一跳轉(zhuǎn),頁面被Unload,其中的ActiveX也就銷毀了;而我們的系統(tǒng)使用的是通過不斷的重繪一張HTML頁面實(shí)現(xiàn)跳轉(zhuǎn),也就是系統(tǒng)永不會(huì)刷新,也就沒有Unload,ActiveX自然無法銷毀,導(dǎo)致瀏覽器崩潰。
解決方法
知道了原因,我們就想想法子。既然IE無法幫我們銷毀ActiveX控件。我們自己來就好了:
代碼如下:
//@AcitveXObjectID: 要查找的節(jié)點(diǎn)范圍,從此節(jié)點(diǎn)一下查找待刪除的ActiveX。
//@ContianerID: 要?jiǎng)h除的ActiveX控件ID。
function ActiveXKiller(AcitveXObjectID,ContianerID){
var ce=document.getElementById(ContianerID);
if (ce){
var cce=ce.children;
for(var i=0;i
if(cce[i].id==AcitveXObjectID){
ce.removeChild(cce[i]);
}
}
}
}
這個(gè)方法就是用來干掉ActiveX控件的。 原理也簡單。就是根據(jù)給定的一個(gè)節(jié)點(diǎn)范圍內(nèi)(一般是ActiveX控件的父節(jié)點(diǎn)、容器), 用給定的ActiveX在Dom中的ID來逐級(jí)查找,一旦找到就手動(dòng)Remove。
有了這個(gè)Killer,我們就能在頁面重繪之前,先搞定ActiveX,避免了崩潰。
另外要提到的,有一個(gè)特殊情況。就是當(dāng)你將一個(gè)ActiveX控件放在了一個(gè)Ext.Window 里。而天真地想讓Ext.Window在關(guān)閉的時(shí)候順帶幫你把里面的ActiveX也銷毀,就必須符合一個(gè)條件:
ActiveX的容器必須是Ext.Window本身。
也就是說:如果你將ActiveX控件放在一個(gè)Ext.Panel里,然后再放在Ext.Window里。就別指望Ext.Window關(guān)閉的時(shí)候可以帶你的ActiveX控件“一起走”了。
GoodLuck!
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com
EXTJS內(nèi)使用ACTIVEX控件引起崩潰問題的解決方法_extjs
EXTJS內(nèi)使用ACTIVEX控件引起崩潰問題的解決方法_extjs:問題 在本人目前的項(xiàng)目中,前端部分完全使用EXTJS基于One-Page理念搭建。除了一個(gè)HTML作為基本容器外,就全是JS文件了(頁面是由JS文件實(shí)現(xiàn)的)。當(dāng)用戶切換頁面時(shí)候,我們通過析構(gòu)上一個(gè)頁面對(duì)象,然后創(chuàng)建新頁面對(duì)象并展現(xiàn)在HTML中。基于這種架構(gòu),我們