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 相关文章推荐
Javascript图像处理—亮度对比度应用案例
Jan 03 Javascript
JSON+JavaScript处理JSON的简单例子
Mar 20 Javascript
javascript-简单的计算器实现步骤分解(附图)
May 30 Javascript
js中的cookie的读写操作示例详解
Apr 17 Javascript
jquery库文件略庞大用纯js替换jquery的方法
Aug 12 Javascript
JS实现仿google、百度搜索框输入信息智能提示的实现方法
Apr 20 Javascript
微信小程序  checkbox组件详解及简单实例
Jan 10 Javascript
vue.js+Element实现表格里的增删改查
Jan 18 Javascript
[js高手之路]HTML标签解释成DOM节点的实现方法
Aug 31 Javascript
React数据传递之组件内部通信的方法
Dec 31 Javascript
React教程之封装一个Portal可复用组件的方法
Jan 02 Javascript
elementUI同一页面展示多个Dialog的实现
Nov 19 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
dhtmlxTree目录树增加右键菜单以及拖拽排序的实现方法
2013/04/26 PHP
PHP封装的字符串加密解密函数
2015/12/18 PHP
php编译安装php-amq扩展简明教程
2016/06/25 PHP
php array_walk_recursive 使用自定的函数处理数组中的每一个元素
2016/11/16 PHP
laravel 框架实现无限级分类的方法示例
2019/10/31 PHP
js数组的操作详解
2013/03/27 Javascript
javascript控制在光标位置插入文字适合表情的插入
2014/06/09 Javascript
AngularJS HTML编译器介绍
2014/12/06 Javascript
JavaScript中数组添加值和访问值常见问题
2016/02/06 Javascript
JavaScript面试题大全(推荐)
2016/09/22 Javascript
详解JavaScript添加给定的标签选项
2018/09/17 Javascript
angular 服务随记小结
2019/05/06 Javascript
JavaScript表格隔行变色和Tab标签页特效示例【附jQuery版】
2019/07/11 jQuery
layui(1.0.9)文件上传upload,前后端的实例代码
2019/09/26 Javascript
webpack4 配置 ssr 环境遇到“document is not defined”
2019/10/24 Javascript
JS实现滑动插件
2020/01/15 Javascript
[01:02:17]2014 DOTA2华西杯精英邀请赛 5 24 DK VS VG
2014/05/26 DOTA
[01:12:35]Spirit vs Navi Supermajor小组赛 A组败者组第一轮 BO3 第二场 6.2
2018/06/03 DOTA
[20:39]DOTA2-DPC中国联赛 正赛开幕式 1月18日
2021/03/11 DOTA
Python实现连接postgresql数据库的方法分析
2017/12/27 Python
python爬取m3u8连接的视频
2018/02/28 Python
Django中url的反向查询的方法
2018/03/14 Python
python 动态迁移solr数据过程解析
2019/09/04 Python
关于numpy数组轴的使用详解
2019/12/05 Python
利用Python自动化操作AutoCAD的实现
2020/04/01 Python
增大python字体的方法步骤
2020/07/05 Python
jupyter notebook更换皮肤主题的实现
2021/01/07 Python
打造经典复古风格的品牌:Alice + Olivia(爱丽丝+奥利维亚)
2016/09/07 全球购物
英国最大的汽车交易网站:Auto Trader UK
2016/09/23 全球购物
女大学生毕业找工作的自我评价
2013/10/03 职场文书
开会迟到检讨书
2014/01/08 职场文书
不错的求职信范文
2014/07/20 职场文书
简单租房协议书范本
2014/08/20 职场文书
如何在C++中调用Python
2021/05/21 Python
Java 超详细讲解设计模式之中的抽象工厂模式
2022/03/25 Java/Android
golang生成并解析JSON
2022/04/14 Golang