欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Vue框架下引入ActiveX控件的问题解决

程序员文章站 2023-11-05 23:45:04
最近参与了山东某一公司的呼叫中心系统的开发项目,我负责的模块是在公司已有的前端vue框架下集成他们的软电话条功能。从开始到结束所遇到的几个问题如下: 1.如何将activ...

最近参与了山东某一公司的呼叫中心系统的开发项目,我负责的模块是在公司已有的前端vue框架下集成他们的软电话条功能。从开始到结束所遇到的几个问题如下:

1.如何将activex控件引入vue,并且在页面上成功渲染;

2.如何调用activex已提供的方法;

3.如何监听activex的动作;

(注:以上问题在html的文件里不存在)

我们先来看下第一个问题:如何将activex控件引入vue,并且在页面上成功渲染。如何将activex控件渲染到页面上。根据客户开发人员提供的demo,`<object id="" classid=""></object>`拷贝到vue文件中,如图所示

Vue框架下引入ActiveX控件的问题解决

yarn run dev,运行成功,但是页面空出很大一块空白区域,很显然,没有渲染成功。经过查询,activex控件只支持在ie浏览器下使用(有点坑)

这算是解决了第一个问题,同样,小伙伴可以通过动态生成的方式渲染到页面上,代码如下:

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("要渲染的节点");
_obj.appendchild(obj)

接下来我们来看第二个问题:如何调用activex已提供的方法。

渲染是可以了,但是却无法调用控件提供的方法。根据demo:`softphonecontrol.makecall(paramsitem)`,无法执行,后来又采取嵌入iframe方式(还记得刚刚说的吗,这个控件在单纯的html页面没有任何问题,当然前提是ie浏览器)。最终找到原因,ie的浏览器需要做下设置设置:设置-internet选项-安全/自定义级别-active控件和插件-对未标记为可安全执行脚本的activex控件初始化并执行脚本,选择"启用"或者"提示")

最后一个问题啦:如何监听activex的动作。

根据demo:

<script  for= "softphonecontrol"  event= "onlogringup(param1,param2)"  language= "javascript"> 
 alert("param1:"+param1+" "+"param2:"+param2); 
</script> 

再次提醒一下,这种写法也只有ie支持,谷歌支持一些简单的window.reload、onclick之类的方法,<script></script>中间的alert就是监听后续需要做的事情。我将这段代码直接拷贝到vue文件里:

Vue框架下引入ActiveX控件的问题解决

哈哈,成功编译,但是无法监听到。换个思路,动态渲染到根节点呢,像上面提到的:

 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)
   },

值得注意的是:此方法会将<script>function</script>渲染到页面上,但是想执行vue的methods的方法的话,还需要在mounted里加上一句代码: window.phonelistener = this;

这段代码的作用是将vue的this所指向赋值给全局的变量phonelistener,这个变量,可随意。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。