gpt4 book ai didi

reactjs - onKeyDown 事件不适用于 React 中的 div

转载 作者:行者123 更新时间:2023-12-03 12:54:20 31 4
gpt4 key购买 nike

我想在 React 中的 div 上使用 keyDown 事件。我愿意:

  componentWillMount() {
document.addEventListener("keydown", this.onKeyPressed.bind(this));
}

componentWillUnmount() {
document.removeEventListener("keydown", this.onKeyPressed.bind(this));
}

onKeyPressed(e) {
console.log(e.keyCode);
}

render() {
let player = this.props.boards.dungeons[this.props.boards.currentBoard].player;
return (
<div
className="player"
style={{ position: "absolute" }}
onKeyDown={this.onKeyPressed} // not working
>
<div className="light-circle">
<div className="image-wrapper">
<img src={IMG_URL+player.img} />
</div>
</div>
</div>
)
}

它工作得很好,但我想用 React 风格做更多。我试过了

onKeyDown={this.onKeyPressed}

在组件上。但它没有反应。我记得它适用于输入元素。

Codepen

我该怎么做?

最佳答案

您应该使用 tabIndex 属性来监听 React 中 div 上的 onKeyDown 事件。设置 tabIndex="0" 应该会触发您的处理程序。

关于reactjs - onKeyDown 事件不适用于 React 中的 div,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43503964/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com