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


Posted in Javascript onMarch 25, 2019

最近参与了山东某一公司的呼叫中心系统的开发项目,我负责的模块是在公司已有的前端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,这个变量,可随意。

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

Javascript 相关文章推荐
JQuery实现表格中相同单元格合并示例代码
Jun 26 Javascript
JavaScript实现按Ctrl键打开新页面
Sep 04 Javascript
详解JavaScript中的4种类型识别方法
Sep 14 Javascript
js中判断变量类型函数typeof的用法总结
Aug 09 Javascript
JavaScript中的await/async的作用和用法
Oct 31 Javascript
js css3实现图片拖拽效果
Mar 04 Javascript
$.browser.msie 为空或不是对象问题的多种解决方法
Mar 19 Javascript
详解微信小程序 登录获取unionid
Jun 27 Javascript
JS算法题之查找数字在数组中的索引位置
May 15 Javascript
javascript实现图片轮播代码
Jul 09 Javascript
JavaScript中变量提升机制示例详解
Dec 27 Javascript
vue修饰符.capture和.self的区别
Apr 22 Vue.js
9102了,你还不会移动端真机调试吗
Mar 25 #Javascript
详解原生JS回到顶部
Mar 25 #Javascript
javascript验证form表单数据的案例详解
Mar 25 #Javascript
elementUI select组件默认选中效果实现的方法
Mar 25 #Javascript
详解javascript函数写法大全
Mar 25 #Javascript
vue在自定义组件中使用v-model进行数据绑定的方法
Mar 25 #Javascript
Node.js之readline模块的使用详解
Mar 25 #Javascript
You might like
PHP排序算法的复习和总结
2012/02/15 PHP
php fsockopen解决办法 php实现多线程
2014/01/20 PHP
一个简洁实用的PHP缓存类完整实例
2014/07/26 PHP
阿里云PHP SMS短信服务验证码发送方法
2017/07/11 PHP
详解php反序列化
2020/06/10 PHP
Javascript YUI 读码日记之 YAHOO.util.Dom - Part.2 0
2008/03/22 Javascript
Jquery下:nth-child(an+b)的使用注意
2011/05/28 Javascript
JQuery通过Ajax提交表单并返回结果
2011/07/31 Javascript
jQuery源码分析-02正则表达式 RegExp 常用正则表达式
2011/11/14 Javascript
jQuery使用zTree插件实现树形菜单和异步加载
2016/02/25 Javascript
JavaScript高级程序设计(第三版)学习笔记6、7章
2016/03/11 Javascript
BootStrap tab选项卡使用小结
2020/08/09 Javascript
JS 学习总结之正则表达式的懒惰性和贪婪性
2017/07/03 Javascript
详解微信小程序Page中data数据操作和函数调用
2017/09/27 Javascript
JS中offset和匀速动画详解
2018/02/06 Javascript
ES6关于Promise的用法详解
2018/05/07 Javascript
vue中vee validate表单校验的几种基本使用
2018/06/25 Javascript
分享5个顶级的JavaScript Ajax组件库
2018/09/16 Javascript
微信小程序map组件结合高德地图API实现wx.chooseLocation功能示例
2019/01/23 Javascript
node 文件上传接口的转发的实现
2019/09/23 Javascript
javascript实现移动端上传图片功能
2020/08/18 Javascript
vue组件中传值EventBus的使用及注意事项说明
2020/11/16 Javascript
[48:45]Ti4 循环赛第二日 NEWBEE vs EG
2014/07/11 DOTA
Python中反射和描述器总结
2018/09/23 Python
Python XML转Json之XML2Dict的使用方法
2019/01/15 Python
使用python绘制二元函数图像的实例
2019/02/12 Python
tensorflow实现在函数中用tf.Print输出中间值
2020/01/21 Python
Pycharm创建文件时自动生成文件头注释(自定义设置作者日期)
2020/11/24 Python
澳大利亚网上玩具商店:Mr Toys Toyworld
2018/03/25 全球购物
英国50岁以上人群的交友网站:Ourtime
2018/03/28 全球购物
金融专业个人求职信范文
2013/11/28 职场文书
违反工作纪律检讨书
2014/02/15 职场文书
汉语言文学毕业求职信
2014/07/17 职场文书
个人股份合作协议书
2014/10/24 职场文书
结婚典礼主持词
2015/06/29 职场文书
解决persistence.xml配置文件修改存放路径的问题
2022/02/24 Java/Android