Vue框架下引入ActiveX控件的問(wèn)題解決
最近參與了山東某一公司的呼叫中心系統(tǒng)的開(kāi)發(fā)項(xiàng)目,我負(fù)責(zé)的模塊是在公司已有的前端Vue框架下集成他們的軟電話條功能。從開(kāi)始到結(jié)束所遇到的幾個(gè)問(wèn)題如下:
1.如何將ActiveX控件引入Vue,并且在頁(yè)面上成功渲染;
2.如何調(diào)用ActiveX已提供的方法;
3.如何監(jiān)聽(tīng)ActiveX的動(dòng)作;
(注:以上問(wèn)題在html的文件里不存在)
我們先來(lái)看下第一個(gè)問(wèn)題:如何將ActiveX控件引入Vue,并且在頁(yè)面上成功渲染。如何將ActiveX控件渲染到頁(yè)面上。根據(jù)客戶(hù)開(kāi)發(fā)人員提供的demo,`<object id="" classid=""></object>`拷貝到vue文件中,如圖所示

yarn run dev,運(yùn)行成功,但是頁(yè)面空出很大一塊空白區(qū)域,很顯然,沒(méi)有渲染成功。經(jīng)過(guò)查詢(xún),ActiveX控件只支持在IE瀏覽器下使用(有點(diǎn)坑)
這算是解決了第一個(gè)問(wèn)題,同樣,小伙伴可以通過(guò)動(dòng)態(tài)生成的方式渲染到頁(yè)面上,代碼如下:
let obj = document.createElement('object')
obj.setAttribute('id', 'activex')
obj.setAttribute('classid', 'clsid:{控件id}')
obj.setAttribute('width', 1500)
obj.setAttribute('height', 100)
var _obj = document.getElementById("要渲染的節(jié)點(diǎn)");
_obj.appendChild(obj)
接下來(lái)我們來(lái)看第二個(gè)問(wèn)題:如何調(diào)用ActiveX已提供的方法。
渲染是可以了,但是卻無(wú)法調(diào)用控件提供的方法。根據(jù)demo:`softphonecontrol.MakeCall(paramsItem)`,無(wú)法執(zhí)行,后來(lái)又采取嵌入iframe方式(還記得剛剛說(shuō)的嗎,這個(gè)控件在單純的html頁(yè)面沒(méi)有任何問(wèn)題,當(dāng)然前提是IE瀏覽器)。最終找到原因,IE的瀏覽器需要做下設(shè)置設(shè)置:設(shè)置-Internet選項(xiàng)-安全/自定義級(jí)別-Active控件和插件-對(duì)未標(biāo)記為可安全執(zhí)行腳本的ActiveX控件初始化并執(zhí)行腳本,選擇"啟用"或者"提示")
最后一個(gè)問(wèn)題啦:如何監(jiān)聽(tīng)ActiveX的動(dòng)作。
根據(jù)demo:
<script for= "softphonecontrol" event= "OnLogRingUp(param1,param2)" language= "javascript">
alert("param1:"+param1+" "+"param2:"+param2);
</script>
再次提醒一下,這種寫(xiě)法也只有IE支持,谷歌支持一些簡(jiǎn)單的window.reload、onclick之類(lèi)的方法,<script></script>中間的alert就是監(jiān)聽(tīng)后續(xù)需要做的事情。我將這段代碼直接拷貝到vue文件里:

哈哈,成功編譯,但是無(wú)法監(jiān)聽(tīng)到。換個(gè)思路,動(dòng)態(tài)渲染到根節(jié)點(diǎn)呢,像上面提到的:
initRingUpSript:function(){
var ring = document.createElement("script");
ring.setAttribute("for","softphonecontrol");
ring.event="OnLogRingUp(Call_ID,CORP_CODE)";
ring.appendChild(document.createTextNode("phoneListener.ringUp(Call_ID,CORP_CODE)"))
document.body.appendChild(ring)
},
值得注意的是:此方法會(huì)將<script>function</script>渲染到頁(yè)面上,但是想執(zhí)行Vue的methods的方法的話,還需要在mounted里加上一句代碼: window.phoneListener = this;
這段代碼的作用是將Vue的this所指向賦值給全局的變量phoneListener,這個(gè)變量,可隨意。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue3+vite+移動(dòng)端webview打包后頁(yè)面加載空白問(wèn)題解決辦法
這篇文章主要給大家介紹了關(guān)于vue3+vite+移動(dòng)端webview打包后頁(yè)面加載空白問(wèn)題的解決辦法,文中通過(guò)代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2024-06-06
vue?使用addRoutes動(dòng)態(tài)添加路由及刷新頁(yè)面跳轉(zhuǎn)404路由的問(wèn)題解決方案
我自己使用addRoutes動(dòng)態(tài)添加的路由頁(yè)面,使用router-link標(biāo)簽可以跳轉(zhuǎn),但是一刷新就會(huì)自動(dòng)跳轉(zhuǎn)到我定義的通配符?*?指向的404路由頁(yè)面,這說(shuō)明沒(méi)有找到指定路由才跳到404路由的,這樣的情況如何處理呢,下面小編給大家分享解決方案,一起看看吧2023-10-10
vue3導(dǎo)入excel并解析excel數(shù)據(jù)渲染到表格中(純前端實(shí)現(xiàn))
在Vue中實(shí)現(xiàn)導(dǎo)出Excel有多種方式,可以通過(guò)前端實(shí)現(xiàn),也可以通過(guò)前后端配合實(shí)現(xiàn),下面這篇文章主要給大家介紹了關(guān)于vue3導(dǎo)入excel并解析excel數(shù)據(jù)渲染到表格中的相關(guān)資料,文中介紹的方法是純前端實(shí)現(xiàn),需要的朋友可以參考下2024-04-04
express+vue+mongodb+session 實(shí)現(xiàn)注冊(cè)登錄功能
這篇文章主要介紹了express+vue+mongodb+session 實(shí)現(xiàn)注冊(cè)登錄,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-12-12
Vue.js學(xué)習(xí)筆記之 helloworld
vue是法語(yǔ)中視圖的意思,Vue.js是一個(gè)輕巧、高性能、可組件化的MVVM庫(kù),同時(shí)擁有非常容易上手的API。有需要的小伙伴可以參考下2016-08-08
vue中實(shí)現(xiàn)div可編輯并插入指定元素與樣式
這篇文章主要給大家介紹了關(guān)于vue中實(shí)現(xiàn)div可編輯并插入指定元素與樣式的相關(guān)資料,文中通過(guò)代碼以及圖文將實(shí)現(xiàn)的方法介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用vue具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09
vue.js分頁(yè)中單擊頁(yè)碼更換頁(yè)面內(nèi)容的方法(配合spring springmvc)
下面小編就為大家分享一篇vue.js分頁(yè)中單擊頁(yè)碼更換頁(yè)面內(nèi)容的方法(配合spring springmvc),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-02-02
vue復(fù)制內(nèi)容到剪切板代碼實(shí)現(xiàn)
這篇文章主要給大家介紹了關(guān)于vue復(fù)制內(nèi)容到剪切板代碼實(shí)現(xiàn)的相關(guān)資料,在Web應(yīng)用程序中剪貼板(Clipboard)操作是非常常見(jiàn)的操作之一,需要的朋友可以參考下2023-08-08

