Tôi muốn sử dụng sự kiện keyDown trên div trong React. Tôi làm:sự kiện onKeyDown không hoạt động trên divs trong React
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>
)
}
Nó hoạt động tốt, nhưng tôi muốn làm nhiều hơn trong kiểu phản ứng. Tôi đã thử
onKeyDown={this.onKeyPressed}
trên thành phần. Nhưng nó không phản ứng. Nó hoạt động trên các yếu tố đầu vào như tôi nhớ lại.
Codepen: http://codepen.io/lafisrap/pen/OmyBYG
Tôi làm cách nào?
Rất tiếc. Tôi chắc chắn, tôi chỉ bỏ qua điều này. Nhưng đây không phải là vấn đề. Nó vẫn không hoạt động. – Michael
câu trả lời được cập nhật. Bạn nên nhấp vào div hoặc đưa nó vào tiêu điểm trước khi nhấn bất kỳ phím nào. – Panther
Tôi đã làm. Nó không hoạt động. Tôi đã cập nhật mã ở trên. Nó hoạt động tốt với các lệnh DOM, nhưng không hoạt động theo kiểu React. – Michael