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 相关文章推荐
Mootools 图片展示插件(lightbox,ImageMenu)收集集合
May 21 Javascript
JS辨别访问浏览器判断是android还是ios系统
Aug 19 Javascript
JavaScript+CSS实现仿天猫侧边网页菜单效果
Aug 25 Javascript
jQuery如何使用自动触发事件trigger
Nov 29 Javascript
使用jquery/js获取iframe父子级、同级获取元素的方法
Aug 05 Javascript
jQuery与JavaScript节点创建方法的对比
Nov 18 Javascript
利用jquery实现验证输入的是否是数字、小数,包含保留几位小数
Dec 07 Javascript
jQuery编写设置和获取颜色的插件
Jan 09 Javascript
原生js实现吸顶效果
Mar 13 Javascript
Node.js学习之TCP/IP数据通讯(实例讲解)
Oct 11 Javascript
angularjs实现table增加tr的方法
Feb 27 Javascript
微信小程序中使用ECharts 异步加载数据的方法
Jun 27 Javascript
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 session劫持和防范的方法
2013/11/12 PHP
PHP内核探索:变量概述
2014/01/30 PHP
php中静态类与静态变量用法的区别分析
2015/01/15 PHP
Yii2中设置与获取别名的函数(setAlias和getAlias)用法分析
2016/07/25 PHP
Javascript 获取链接(url)参数的方法
2009/02/15 Javascript
jquery1.4后 jqDrag 拖动 不可用
2010/02/06 Javascript
JS控制文本框textarea输入字数限制的方法
2013/06/17 Javascript
js或jquery实现页面打印可局部打印
2014/03/27 Javascript
asp.net中oracle 存储过程(图文)
2015/08/12 Javascript
jQuery实现向下滑出的二级菜单效果实例
2015/08/22 Javascript
jquery实现可点击伸缩与展开的菜单效果代码
2015/08/31 Javascript
限制复选框最多选择项的实现代码
2016/05/30 Javascript
Radio 单选JS动态添加的选项onchange事件无效的解决方法
2016/12/12 Javascript
Vue.js常用指令的使用小结
2017/06/23 Javascript
浅谈vue-lazyload实现的详细过程
2017/08/22 Javascript
详解Element 指令clickoutside源码分析
2019/02/15 Javascript
微信小程序在ios下Echarts图表不能滑动的问题解决
2019/07/10 Javascript
Layui 带多选框表格监听事件以及按钮自动点击写法实例
2019/09/02 Javascript
layui复选框限制选择个数的方法
2019/09/18 Javascript
[01:11:48]Fnatic vs IG 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/18 DOTA
[46:12]完美世界DOTA2联赛循环赛 DM vs Matador BO2第一场 11.04
2020/11/04 DOTA
python制作最美应用的爬虫
2015/10/28 Python
python利用requests库模拟post请求时json的使用教程
2018/12/07 Python
python3的数据类型及数据类型转换实例详解
2019/08/20 Python
Python编写打字训练小程序
2019/09/26 Python
Django REST框架创建一个简单的Api实例讲解
2019/11/05 Python
tensorflow自定义激活函数实例
2020/02/04 Python
python tkinter之 复选、文本、下拉的实现
2020/03/04 Python
英国第一的滑雪服装和装备零售商:Snow+Rock
2020/02/01 全球购物
制药工程专业应届生求职信
2013/09/24 职场文书
法人委托书范本
2014/04/04 职场文书
人事行政主管岗位职责
2015/04/09 职场文书
城南旧事观后感
2015/06/11 职场文书
贷款工资证明范本
2015/06/12 职场文书
2016年清明节寄语
2015/12/04 职场文书
Python测试框架pytest高阶用法全面详解
2022/06/01 Python