中文键盘 React 组件库

这是一个 React 的中文键盘组件库,支持拼音输入和手写输入。
功能特点
- 🔌 即插即用,自动绑定输入框
- ✨ 支持拼音输入,带候选词选择功能
- ✏️ 支持手写输入识别,支持连笔和简写
- 🔧 可自定义手写识别算法
- 📏 键盘大小可自定义缩放,灵活适配各种界面布局
- 🌐 纯前端实现,可作为静态网页部署,无需服务端支持
安装
npm install @zh-keyboard/react
yarn add @zh-keyboard/react
pnpm add @zh-keyboard/react
属性
Props
defaultMode | 'en' | 'zh' | 'hand' | 'num' | 'en' | 默认的键盘模式 |
enableHandwriting | boolean | false | 是否启用手写输入 |
position | 'static' | 'float' | 'bottom' | 'static' | 键盘定位模式 |
value | string | '' | 输入框的值 |
onChange | function | - | 值变化时的回调函数 |
事件
onKey | KeyEvent | 当用户在键盘上点击按键时触发 |
基本使用
- 为了防止移动端设备弹出系统默认的键盘,建议在输入框上设置
inputMode="none"
属性。
- 此外,可以通过在输入框上设置
data-inputmode
属性来指定组件默认打开的键盘类型 (可选值为 'en'
, 'zh'
, 'hand'
, 'num'
),具体键盘模式的说明请参考 defaultMode
属性。
import { ZhKeyboard } from '@zh-keyboard/react'
import { useState } from 'react'
import '@zh-keyboard/react/dist/style.css'
function App() {
const [inputText, setInputText] = useState('')
return (
<div>
<input
value={inputText}
onChange={e => setInputText(e.target.value)}
data-inputmode="en"
inputMode="none"
placeholder="点击使用键盘输入"
/>
{/* 静态定位的键盘 */}
<ZhKeyboard
value={inputText}
onChange={setInputText}
/>
{/* 浮动定位的键盘(跟随输入框) */}
<ZhKeyboard
value={inputText}
onChange={setInputText}
position="float"
/>
{/* 底部固定的键盘 */}
<ZhKeyboard
value={inputText}
onChange={setInputText}
position="bottom"
/>
{/* 启用手写输入的键盘 */}
<ZhKeyboard
value={inputText}
onChange={setInputText}
enableHandwriting={true}
/>
{/* 数字键盘 */}
<ZhKeyboard
value={inputText}
onChange={setInputText}
defaultMode="num"
/>
</div>
)
}
export default App
输入模式
拼音输入模式 (zh)
拼音输入模式支持单字拼音输入,具有以下特性:
- 支持单字模糊拼音匹配
- 使用内置词库进行单字匹配
- 支持中英文快速切换
注:目前仅支持单个汉字的拼音输入,连续词组输入功能正在开发中
英文输入模式 (en)
标准的英文键盘布局,支持英文字母、数字和常用符号的输入。
手写输入模式 (hand)
手写输入模式允许用户通过手写输入汉字,启用此模式需要设置 enableHandwriting
为 true
。
数字输入模式 (num)
数字输入模式提供一个数字和小数点键盘,方便用户输入数字、金额等。
手写识别
组件库支持自定义手写识别服务。您可以注册自己的手写识别服务来处理用户的手写输入。
手写识别接口
手写识别服务需要实现以下接口:
interface HandwritingRecognizer {
initialize(): Promise<boolean>
recognize(strokeData: number[]): Promise<string[]>
close(): Promise<void>
}
笔迹数据格式
笔迹数据以数组形式存储,格式为 [x1, y1, c1, x2, y2, c2, ...]
,其中:
x
、y
是坐标点
c
表示是否为笔画的最后一点:1表示是最后一点,0表示不是
例如,一个简单的笔画可能是:[100, 150, 0, 101, 151, 0, 102, 152, 1]
,表示三个点的笔画,最后一个点是笔画的结束点。
注册手写识别服务
import { registerHandwritingRecognizer } from '@zh-keyboard/react'
import { MyHandwritingRecognizer } from './MyHandwritingRecognizer'
const recognizer = new MyHandwritingRecognizer()
registerHandwritingRecognizer(recognizer)
示例实现
以下是一个简单的手写识别服务示例实现:
import type { HandwritingRecognizer } from '@zh-keyboard/react'
export class MyHandwritingRecognizer implements HandwritingRecognizer {
private initialized = false
async initialize(): Promise<boolean> {
console.log('初始化手写识别服务...')
this.initialized = true
return true
}
async recognize(strokeData: number[]): Promise<string[]> {
if (!this.initialized) {
throw new Error('手写识别服务未初始化')
}
console.log('识别笔迹数据:', strokeData)
return ['你', '我', '他', '好', '的']
}
async close(): Promise<void> {
console.log('关闭手写识别服务')
this.initialized = false
}
}
生命周期
- 当手写输入组件挂载时,会自动调用手写识别服务的
initialize()
方法
- 当用户完成一个笔画时,会调用
recognize()
方法进行识别
- 当手写输入组件卸载时,会调用
close()
方法关闭手写识别服务