web-dev-qa-db-ja.com

React JSでEnterキーが押されたときに入力テキストフィールド値を取得するにはどうすればよいですか?

ユーザーがキーボードのEnterキーを押したときにtextfield値を渡したい。 onChange()イベントでは、textboxの値を取得していますが、enterキーが押されたときにこの値を取得する方法は?

コード:

import TextField from 'material-ui/TextField';

class CartridgeShell extends Component {

   constructor(props) {
      super(props);
      this.state = {value:''}
      this.handleChange = this.handleChange.bind(this);
   }

   handleChange(e) {
      this.setState({ value: e.target.value });
   }

   render(){
      return(
         <TextField 
             hintText="First Name" 
             floatingLabelText="First Name*"
             value={this.state.value} 
             onChange={this.handleChange} 
             fullWidth={true} />
      )
   }
}
27
Soumya Behera

onKeyDownイベントを使用し、その内部でユーザーが押したキーのキーコードを確認します。 Enterキーのキーコードは13です。コードを確認し、そこにロジックを配置します。

この例を確認してください:

class CartridgeShell extends React.Component {

   constructor(props) {
      super(props);
      this.state = {value:''}

      this.handleChange = this.handleChange.bind(this);
      this.keyPress = this.keyPress.bind(this);
   } 
 
   handleChange(e) {
      this.setState({ value: e.target.value });
   }

   keyPress(e){
      if(e.keyCode == 13){
         console.log('value', e.target.value);
         // put the login here
      }
   }

   render(){
      return(
         <input value={this.state.value} onKeyDown={this.keyPress} onChange={this.handleChange} fullWidth={true} />
      )
    }
}

ReactDOM.render(<CartridgeShell/>, document.getElementById('app'))
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react-dom.min.js"></script>


<div id = 'app' />

注:input要素をMaterial-Ui TextFieldに置き換え、他のプロパティも定義します。

44
Mayank Shukla

OnKeyPressを追加すると、テキストフィールドでonChangeが機能します。

<TextField
  onKeyPress={(ev) => {
    console.log(`Pressed keyCode ${ev.key}`);
    if (ev.key === 'Enter') {
      // Do code here
      ev.preventDefault();
    }
  }}
/>
10
sunaina kotekar

html

<input id="something" onkeyup="key_up(this)" type="text">

script

function key_up(e){
    var enterKey = 13; //Key Code for Enter Key
    if (e.which == enterKey){
        //Do you work here
    }
}

次回は、いくつかのコードを提供してみてください。

0
manish