reactjs - 与打字稿反应的按键事件
问题描述
各位晚上好,
我正在编写一种方法,当将特定字符(或键)按下到文本框中时,该方法应插入特定字符串。在这种情况下,该字符是不可打印的字符,在大多数字体系列中不提供视觉表示,但仍可检测到。
Input: U+0030 => Output: '<TAG1>'
Input: U+0029 => Output: '<TAG2>'
当检测到按键时,插入需要立即发生。我正在尝试利用 React 按键事件,但需要一些额外的帮助。
我正在嗅探按键事件的文本框位于 a 中<FormField>
,这是我到目前为止的代码:
private onKeyDown = (e: React.KeyboardEvent<HTMLFormElement>) => {
switch (e.key) {
case String.fromCharCode(4):
//textbox.append("<TAG>") unsure how to implement
break;
case String.fromCharCode(29):
//textbox.append("<TAG>") unsure how to implement
break;
case String.fromCharCode(30):
//textbox.append("<TAG>") unsure how to implement
break;
}
}
解决方案
尽管这似乎是一项非常简单的任务,但您需要注意不要在处理此类事件时造成糟糕的用户体验。
正如评论中提到的,受控输入是在这里使用的正确方法。我整理了一个简短的例子:
import React from "react";
export default function App() {
const [input, setInput] = React.useState("");
const handleInput = (event: React.ChangeEvent<HTMLInputElement>) => {
setInput(event.target.value);
};
const handleKeyDown = (event: React.KeyboardEvent<HTMLInputElement>) => {
if ([9, 112].indexOf(event.keyCode) !== -1) {
event.preventDefault();
event.stopPropagation();
}
console.log(event.keyCode);
switch (event.keyCode) {
case 9:
setInput(`${input}<TAB>`);
break;
case 112:
setInput(`${input}<F1>`);
break;
default:
break;
}
};
return (
<div className="App">
<input
type="text"
value={input}
onChange={handleInput}
onKeyDown={handleKeyDown}
/>
<div>Value: "{input}"</div>
</div>
);
}
代码可以在这里试用。
首先,您会看到一个包含输入值的状态。随后是onChange
处理程序,它只是将当前值写入状态。handleKeyDown
在聚焦输入时,每按下一个键都会调用该事件。您需要注意以下事项:
- 防止默认操作,因此捕获的键不会与其他任何东西混淆。例如,您希望在TAB被击中时保持输入焦点。
- 还要停止传播,因为您已经操纵了输入值,所以没有其他事件应该是相同的。
- 示例中未解决的是,如果您按下多个键会发生什么。例如CTRL- Backspace。这可能会导致糟糕的用户体验。