试图找出为什么这里的 if 语句只在用户第二次按下某个键时运行。我试图让它从按下第一个键开始运行。
功能:
const commentFieldHasText = () => {
const commentInput = document.querySelector('.add-comment')
console.log('runs first keypress')
if (commentInput.value) {
console.log('only runs second keypress')
}
}
输入:
<input
className="add-comment"
placeholder="Add a public comment"
onKeyDown={() => commentFieldHasText()}
/>
其他信息: onKeyPress 也没有提供预期的功能。 onKeyUp 确实如此。
最佳答案
发生这种情况是因为 keydown
和 keypress
事件发生在实际按键输入之前。
要解决此问题,请尝试使用 input
或 keyup
事件。
关于javascript - if 语句仅在按下第二个键时运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59347684/