• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    EXTJS內使用ACTIVEX控件引起崩潰問題的解決方法_extjs

    來源:懂視網 責編:小采 時間:2020-11-27 20:48:17
    文檔

    EXTJS內使用ACTIVEX控件引起崩潰問題的解決方法_extjs

    EXTJS內使用ACTIVEX控件引起崩潰問題的解決方法_extjs:問題 在本人目前的項目中,前端部分完全使用EXTJS基于One-Page理念搭建。除了一個HTML作為基本容器外,就全是JS文件了(頁面是由JS文件實現的)。當用戶切換頁面時候,我們通過析構上一個頁面對象,然后創建新頁面對象并展現在HTML中。基于這種架構,我們
    推薦度:
    導讀EXTJS內使用ACTIVEX控件引起崩潰問題的解決方法_extjs:問題 在本人目前的項目中,前端部分完全使用EXTJS基于One-Page理念搭建。除了一個HTML作為基本容器外,就全是JS文件了(頁面是由JS文件實現的)。當用戶切換頁面時候,我們通過析構上一個頁面對象,然后創建新頁面對象并展現在HTML中。基于這種架構,我們

    問題
    在本人目前的項目中,前端部分完全使用EXTJS基于“One-Page”理念搭建。除了一個HTML作為基本容器外,就全是JS文件了(頁面是由JS文件實現的)。當用戶切換頁面時候,我們通過析構上一個頁面對象,然后創建新頁面對象并展現在HTML中。基于這種架構,我們還引入了一個ActiveX控件,用于展現報表。這一引入,問題就出來了:只要是訪問有報表控件存在的頁面,用戶切換2次頁面,IE就會崩潰(FF無此問題),百試不爽。
    原因
    因為系統設計時考慮到了資源釋放,專門處理過析構部分,而且無ActiveX的頁面不存在問題。故問題肯定是出在IE對包含在JS中的ActiveX控件釋放出了問題。畢竟在傳統的以HTML或JSP、PHP頁搭建的前端中,ActiveX是屬于頁面的,只要用戶一跳轉,頁面被Unload,其中的ActiveX也就銷毀了;而我們的系統使用的是通過不斷的重繪一張HTML頁面實現跳轉,也就是系統永不會刷新,也就沒有Unload,ActiveX自然無法銷毀,導致瀏覽器崩潰。
    解決方法
    知道了原因,我們就想想法子。既然IE無法幫我們銷毀ActiveX控件。我們自己來就好了:
    代碼如下:
    //@AcitveXObjectID: 要查找的節點范圍,從此節點一下查找待刪除的ActiveX。
    //@ContianerID: 要刪除的ActiveX控件ID。
    function ActiveXKiller(AcitveXObjectID,ContianerID){
    var ce=document.getElementById(ContianerID);
    if (ce){
    var cce=ce.children;
    for(var i=0;iif(cce[i].id==AcitveXObjectID){
    ce.removeChild(cce[i]);
    }
    }
    }
    }

    這個方法就是用來干掉ActiveX控件的。 原理也簡單。就是根據給定的一個節點范圍內(一般是ActiveX控件的父節點、容器), 用給定的ActiveX在Dom中的ID來逐級查找,一旦找到就手動Remove。
    有了這個Killer,我們就能在頁面重繪之前,先搞定ActiveX,避免了崩潰。
    另外要提到的,有一個特殊情況。就是當你將一個ActiveX控件放在了一個Ext.Window 里。而天真地想讓Ext.Window在關閉的時候順帶幫你把里面的ActiveX也銷毀,就必須符合一個條件:
    ActiveX的容器必須是Ext.Window本身。
    也就是說:如果你將ActiveX控件放在一個Ext.Panel里,然后再放在Ext.Window里。就別指望Ext.Window關閉的時候可以帶你的ActiveX控件“一起走”了。
    GoodLuck!

    聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    EXTJS內使用ACTIVEX控件引起崩潰問題的解決方法_extjs

    EXTJS內使用ACTIVEX控件引起崩潰問題的解決方法_extjs:問題 在本人目前的項目中,前端部分完全使用EXTJS基于One-Page理念搭建。除了一個HTML作為基本容器外,就全是JS文件了(頁面是由JS文件實現的)。當用戶切換頁面時候,我們通過析構上一個頁面對象,然后創建新頁面對象并展現在HTML中。基于這種架構,我們
    推薦度:
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 久久青青草原精品国产| 蜜芽亚洲av无码精品色午夜| 亚洲精品欧美二区三区中文字幕 | 久久精品国产精品亚洲| 99热国内精品| 日韩精品无码免费一区二区三区 | 乱人伦人妻精品一区二区| 久久精品国产免费| 国产精品女同久久久久电影院| 亚洲精品网站在线观看不卡无广告 | 日韩精品欧美国产在线| 久久青草国产精品一区| 亚洲精品无码永久在线观看你懂的| 国自产精品手机在线观看视频| 四虎国产精品免费久久5151| 91精品国产福利在线导航| 中文字幕精品无码久久久久久3D日动漫 | 麻豆aⅴ精品无码一区二区| 国内精品久久久久久久影视麻豆| 好属妞这里只有精品久久| 国产精品无码一区二区三级| 久久久久人妻一区精品色| 亚洲性日韩精品国产一区二区| 久久99精品久久久久久齐齐| 国产精品男男视频一区二区三区| 日韩精品一区二区三区大桥未久 | 精品人妻系列无码天堂| 亚洲国产精品高清久久久| 亚洲中文久久精品无码| 亚洲电影日韩精品 | 亚洲愉拍自拍欧美精品| 欧美精品第欧美第12页| 国产精品久久久久久福利漫画| 国产精品露脸国语对白| 99re6这里有精品热视频| 成人区精品一区二区不卡| 国内精品久久久久久久97牛牛| 精品国产一区二区三区不卡| 精品久久久久久久久午夜福利| 国产办公室秘书无码精品99| 成人精品视频在线观看|