如何在vue中优雅的使用ocx控件:控件引用

最近刚好在做一个自助机项目,限于个人技术栈,也是为了后期更新维护方便,采用了BS的形式来开发。

自助机需要控制摄像头、身份证读卡器、扫描仪、手写签名等硬件,目前只有IE的ocx控件可以提供比较好的支持,所以客户端浏览器定为IE。之前主要是用vue和element-ui来写管理后端,怎么将vue和ocx结合使用是一个全新的课题。在一通百度之后,发现网上并没有完整的例子,于是自己一番折腾,终于可以比较优雅的在vue中使用ocx了。

问题一:控件如何引用

在传统项目中,ocx控件都是以object标签的形式插入到页面,只能加载一次,但是vue的页面是动态添加和删除的,所以object标签是适合放置在vue的组件中的。最好的做法是直接将object标签添加到 index.html,这样就可以避免控件加载问题。





  
  
  
  
  xx系统



  

问题二:vue中怎么使用ocx对象

这个问题相对简单,直接使用 window.obj,或者直接通过id获取 document.getElementById('CVR_IDCard'),这两种方式都不会提示语法错误。个人更倾向于方式2,除了可以使用控件的方法,还能方便的改变控件样式。

// 方式 1
window.CVR_IDCard

//方式 2
document.getElementById('CVR_IDCard')

后面还有如何使用结合iframe使用ocx、怎么在vue中绑定控件事件。

你可能感兴趣的:(vue)