🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
[TOC] ## 环境要求 * npm * vue * vuex * vue-router ## 安装 ### 下载安装依赖 ~~~ npm install vue-epg ~~~ ### 在vue项目中初始化 ~~~ import {VueEpg} from 'vue-epg' //引入组件 //定义并实例化 VueEpg const epg = new VueEpg({ focus_class:'focus', group_name:'.group', actions:['number'], //自定义的方法,在 组件中需指定,名称对应大写的 KeyActions 的Key 如 number 对应 NUMBER setKeyBoardEventListener: service=> { //这里设置各事件监听 //方向 上下左右必须监听 可绑定多个值 document.addEventListener("keydown", event => { const keyCode = event.keyCode ? event.keyCode : event.charCode ? event.charCode : event.which; service.keyActions.UP.push(...[19,38]) //数组中的值响应 按下上键的事件 service.keyActions.DOWN.push(...[20,47,40]) service.keyActions.LEFT.push(...[29,21,37]) service.keyActions.RIGHT.push(...[22,32,39]) service.keyActions.ENTER.push(...[73,66,23]) //类似Click 点击 service.keyActions.BACK.push(...[4,27]) service.keyActions.NUMBER=[49,50,51,52,53,54,55,56,57,48,96,97,98,99,100,101,102,103,104,105] //绑定为数字键 service.eventHandler(keyCode) //注册响应 }) } //vue 绑定 epg 实例 Vue.use(epg) //配置结束 ~~~ ## 获取实例 插件安装完成后可调用实例方法: ~~~ this.$service this.$service.pointer //当前焦点对象 this.$service.move //移动方法 this.$service.clear() //重置服务,通常在页面切换时触发 1.0.15版之前为自动触发,现以移除自动重置,需要在路由守卫中自定义触发 this.$service.getEleByPath //通过xpath获取 元素 el this.$service.getPointerPosition //获取焦点 xpath ~~~