-
For Vue 3.0, Please to using vue-keyboard-virtual-next.
-
For React, Please to using virtual-keyboard-react.
They have the same function as the Vue2.x version
- 支持多达五种键盘模式
- 支持自定义主题色
- 已集成丰富的中文字库
- 支持急速识别的手写能力
- vue 组件开箱即用
Edge | Firefox | Chrome | Safari | Opera |
---|---|---|---|---|
Edge | last 2 versions | last 2 versions | last 2 versions | last 2 versions |
$ npm install keyboard-virtual-vue --save
$ yarn add keyboard-virtual-vue --save
如果你的网络环境不佳,推荐使用 cnpm。
import Vue from "vue";
import App from "./app";
import "keyboard-virtual-vue/keyboard.min.css";
import KeyBoard from "keyboard-virtual-vue";
Vue.use(KeyBoard);
new Vue({
el: "#app",
template: "<App/>",
});
<template>
<!-- keyboard 只识别带有 data-mode 标识的输入框 -->
<input data-mode v-model="value" />
<Key-Board />
</template>
<script>
import "keyboard-virtual-vue/keyboard.min.css";
import KeyBoard from "keyboard-virtual-vue";
export default {
data() {
return {
value: "你好"
};
},
components: { KeyBoard },
};
</script>
属性 | 说明 | 类型 | 可选值 | 默认值 |
---|---|---|---|---|
data-mode | 弹出输入法的类型:en 英文小写number 数字symbol 标点handwrite 手写不传 默认中文 |
String | en number symbol handwrite |
default as * |
data-prop | 注册的输入框的类型 | String | * |
参数 | 说明 | 默认值 | 类型 | 是否必须 | 版本 |
---|---|---|---|---|---|
v-model | 绑定的输入框value,可同时双向绑定多个输入框,不传则只与当前focus输入框做数据绑定关系 | string|number | 否 | v1.0.0+ | |
color | 主题色 | #eaa050 |
string | 否 | v1.0.0+ |
modeList | 键盘渲染模式列表,若不传handApi则不会出现手写板 | ["handwrite", "symbol"] | string[] | 否 | v1.0.0+ |
blurHide | 是否当前输入框blur事件触发隐藏 | true | boolean | 否 | v1.0.0+ |
showHandleBar | 是否显示拖拽句柄 | true | boolean | 否 | v1.0.0+ |
dargHandleText | 拖拽句柄提示文字 | string | 否 | v1.0.0+ | |
modal | 是否显示遮罩层 | false | boolean | 否 | v1.0.0+ |
closeOnClickModal | 是否点击遮罩层隐藏键盘 | true | boolean | 否 | v1.0.0+ |
handApi | 手写识别接口,若不传则无法切换手写模块 | string | 否 | v1.0.0+ | |
animateClass | 键盘显隐动画,内置slide动画,如若需要其他动画,可传入相应类名自定义动画 | string | 否 | v1.0.0+ |
参数 | 说明 | 类型 | 版本 |
---|---|---|---|
keyChange | 按键触发事件,第一个参数为当前触发的按键的标识,第二个参数为当前聚焦输入框的props值,若没有则直接返回当前聚焦的input元素(v1.0.1版本之后) |
(value: string,prop:string|HTMLInputElement) => void | v1.0.0+ |
change | value改变事件,第一个参数为当前最新通过键盘输入的值,第二个参数为当前聚焦输入框的props值,若没有则直接返回当前聚焦的input元素(v1.0.1版本之后) |
(value: string,prop:string|HTMLInputElement) => void | v1.0.0+ |
closed | 键盘关闭事件 | () => void | v1.0.0+ |
modalClick | 遮罩点击事件 | () => void | v1.0.0+ |
方法名 | 说明 | 类型 | 版本 |
---|---|---|---|
signUpKeyboard | 重新给input注册绑定键盘,当页面有新的input标签出现时调用此方法 | () => void | v1.0.0+ |
getCurrentInput | 获取当前聚焦的输入框 | () => HTMLInputElement | null | v1.0.1+ |
- 有问题欢迎提交 Issue。
- 本项目为作者一人维护,精力有限,有限解决重大 bug,望理解。
- 用于生产环境,请使用
release
版本代码 - 暂只支持
vue2.x
版本引入