rks*_*ksh 1 javascript reactjs
我想在输入按键反应后清除textarea内容.但是,当输入键时,文本区域清除但输入键保持不变(换行).我怎样才能解决这个问题?
constructor(){
this.state = { text : '' }
}
keypress(e){
if(e.key == 'Enter'){
this.setState({
send_message: ''
})
}
}
<textarea value={this.state.text} placeholder="Text" rows="1" className="form-textarea typing-area" onKeyPress={this.keypress.bind(this)}></textarea>
Run Code Online (Sandbox Code Playgroud)
您可以event.preventDefault在密钥为"Enter"时使用:
class App extends React.Component {
constructor(props) {
super(props);
this.state = { text : '' }
this.handleChange = this.handleChange.bind(this);
this.keypress = this.keypress.bind(this);
}
handleChange(event) {
this.setState({text: event.target.value});
}
keypress(e){
if(e.key === 'Enter'){
e.preventDefault();
this.setState({
send_message: this.state.text,
text: '',
});
}
}
render() {
return (
<div>
<textarea
value={this.state.text}
placeholder="Text"
rows="1"
className="form-textarea typing-area"
onChange={this.handleChange}
onKeyPress={this.keypress}
/>
<pre>{JSON.stringify(this.state, null, 2)}</pre>
</div>
);
}
}
ReactDOM.render(<App />, document.getElementById('app'));Run Code Online (Sandbox Code Playgroud)
<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"></div>Run Code Online (Sandbox Code Playgroud)