ReactJS에서 'onKeyPress'이벤트를 처리하는 방법은 무엇입니까?
onKeyPress
ReactJS 에서 이벤트를 어떻게 작동시킬 수 있습니까? enter (keyCode=13)
누를 때 경고해야합니다 .
var Test = React.createClass({
add: function(event){
if(event.keyCode == 13){
alert('Adding....');
}
},
render: function(){
return(
<div>
<input type="text" id="one" onKeyPress={this.add} />
</div>
);
}
});
React.render(<Test />, document.body);
나는 0.14.7 사용 반작용 함께 일하고 onKeyPress
과 event.key
잘 작동합니다.
handleKeyPress = (event) => {
if(event.key === 'Enter'){
console.log('enter press here! ')
}
}
render: function(){
return(
<div>
<input type="text" id="one" onKeyPress={this.handleKeyPress} />
</div>
);
}
render: function(){
return(
<div>
<input type="text" id="one" onKeyDown={this.add} />
</div>
);
}
onKeyDown
keyCode
이벤트를 감지 합니다.
나를 위해 onKeyPress
은 e.keyCode
항상 0
있지만, e.charCode
정확한 값을 가지고있다. 경우 사용 onKeyDown
에 올바른 코드를 e.charCode
.
var Title = React.createClass({
handleTest: function(e) {
if (e.charCode == 13) {
alert('Enter... (KeyPress, use charCode)');
}
if (e.keyCode == 13) {
alert('Enter... (KeyDown, use keyCode)');
}
},
render: function() {
return(
<div>
<textarea onKeyPress={this.handleTest} />
</div>
);
}
});
var Test = React.createClass({
add: function(event){
if(event.key === 'Enter'){
alert('Adding....');
}
},
render: function(){
return(
<div>
<input type="text" id="one" onKeyPress={(event) => this.add(event)}/>
</div>
);
}
});
리 액트는 당신이 생각할만한 종류의 사건을 전달하지 않습니다. 오히려, 그것은 합성 사건을 통과하고 있습니다 .
간단한 테스트에서는 event.keyCode == 0
항상 사실입니다. 당신이 원하는 것은event.charCode
파티에 늦었지만 TypeScript 에서이 작업을 수행하려고 시도했으며 다음을 수행했습니다.
<div onKeyPress={(e: KeyboardEvent<HTMLDivElement>) => console.log(e.key)}
This prints the exact key pressed to the screen. So if you want to respond to all "a" presses when the div is in focus, you'd compare e.key to "a" - literally if(e.key === "a").
If you wanted to pass a dynamic param through to a function, inside a dynamic input::
<Input
onKeyPress={(event) => {
if (event.key === "Enter") {
this.doSearch(data.searchParam)
}
}}
placeholder={data.placeholderText} />
/>
Hope this helps someone. :)
There are some challenges when it comes to keypress event. Jan Wolter's article on key events is a bit old but explains well why key event detection can be hard.
A few things to note:
keyCode
,which
,charCode
have different value/meaning in keypress from keyup and keydown. They are all deprecated, however supported in major browsers.- Operating system, physical keyboards, browsers(versions) could all have impact on key code/values.
key
andcode
are the recent standard. However, they are not well supported by browsers at the time of writing.
To tackle keyboard events in react apps, I implemented react-keyboard-event-handler. Please have a look.
Keypress event is deprecated, You should use Keydown event instead.
https://developer.mozilla.org/en-US/docs/Web/API/Document/keypress_event
handleKeyDown(event) {
if(event.keyCode === 13) {
console.log('Enter key pressed')
}
}
render() {
return <input type="text" onKeyDown={this.handleKeyDown} />
}
참고URL : https://stackoverflow.com/questions/27827234/how-to-handle-the-onkeypress-event-in-reactjs
'IT story' 카테고리의 다른 글
캐치 루프 내부 또는 외부로 이동해야합니까? (0) | 2020.05.24 |
---|---|
컴포넌트 외부에서 Vue.js 컴포넌트 메소드 호출 (0) | 2020.05.24 |
필드 이름 주위에 백틱 사용 (0) | 2020.05.24 |
.NET에서 리소스를 만들고 사용하는 방법 (0) | 2020.05.24 |
JavaScript로 객체를 만드는 데 가장 좋은 방법은 무엇입니까? (0) | 2020.05.24 |