如何处理ReactJS中的onKeyPress事件?

2020/10/12 04:41 · javascript ·  · 0评论

如何使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);

我正在使用React 0.14.7,使用onKeyPressevent.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>
     );
}

对我而言onKeyPresse.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>
      );
    }
  });

反应键盘事件

render: function(){
     return(
         <div>
           <input type="text" id="one" onKeyDown={this.add} />
        </div>
     );
}

onKeyDown检测keyCode事件。

不推荐使用Keypress事件,而应该使用Keydown事件。

https://developer.mozilla.org/zh-CN/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} /> 
}
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>
        );
     }
});

React不会给您传递您可能会想到的那种事件。相反,它正在传递综合事件

在简短的测试中,event.keyCode == 0总是正确的。你想要的是event.charCode

如果要将动态参数传递给函数,请在动态输入内部:

<Input 
  onKeyPress={(event) => {
    if (event.key === "Enter") {
      this.doSearch(data.searchParam)
    }
  }}
  placeholder={data.placeholderText} />
/>

希望这对某人有帮助。:)

晚会晚了,但我试图在TypeScript中完成此工作并提出了以下建议:

<div onKeyPress={(e: KeyboardEvent<HTMLDivElement>) => console.log(e.key)}

这将打印在屏幕上的确切键。因此,如果要在div处于焦点状态时响应所有“ a”按下,则可以将e.key与“ a”进行比较-字面上是if(e.key ===“ a”)。

按键事件方面存在一些挑战。扬·沃尔特(Jan Wolter)关于关键事件的文章有些陈旧,但很好地解释了为什么很难检测关键事件。

注意事项:

  1. keyCodewhichcharCode具有不同的值/从KEYUP和KEYDOWN在按键的意思。它们均已弃用,但在主要浏览器中受支持。
  2. 操作系统,物理键盘,浏览器(版本)都可能对键代码/值产生影响。
  3. key并且code是最新标准。但是,在撰写本文时,浏览器还没有很好地支持它们。

为了处理react应用中的键盘事件,我实现了react-keyboard-event-handler请看一看。

在此处输入图片说明

您可以检查此功能“按Enter”

本文地址:http://javascript.askforanswer.com/ruhechulireactjszhongdeonkeypressshijian.html
文章标签: ,   ,   ,  
版权声明:本文为原创文章,版权归 javascript 所有,欢迎分享本文,转载请保留出处!

文件下载

老薛主机终身7折优惠码boke112

上一篇:
下一篇:

评论已关闭!