admin管理员组文章数量:1342623
I am new to reactjs and trying to print update value of input field. What I firstly tried was this:
var App = React.createClass({
render() {
return <div>
<h1>Hello, {this.props.name}</h1>
<input type="text" onKeyUp={this.handleChange} />
<p>{this.handleChange}</p>
</div>;
},
handleChange: function(event) {
return event.target.value;
}
});
App = React.createFactory(App);
React.render(
<App name="World" />,
document.getElementById('mount-point'));
But I don't get it why it is not working. Than I tried this: CodePen maybe someone can help me with printing instantly the value of the input field in the <p>
element
I am new to reactjs and trying to print update value of input field. What I firstly tried was this:
var App = React.createClass({
render() {
return <div>
<h1>Hello, {this.props.name}</h1>
<input type="text" onKeyUp={this.handleChange} />
<p>{this.handleChange}</p>
</div>;
},
handleChange: function(event) {
return event.target.value;
}
});
App = React.createFactory(App);
React.render(
<App name="World" />,
document.getElementById('mount-point'));
But I don't get it why it is not working. Than I tried this: CodePen maybe someone can help me with printing instantly the value of the input field in the <p>
element
-
You need to store the value of the change into state (e.g.
this.setState({ myInputValue: event.target.value });
) within yourhandleChange
. Then you can "print" the value in yourp
like so:<p>{this.state.myInputValue}</p>
. – ctrlplusb Commented Oct 4, 2016 at 9:56 - Highly remend you go through the docs and tutorials. facebook.github.io/react/docs/thinking-in-react.html Otherwise you are just guessing at the API. – ctrlplusb Commented Oct 4, 2016 at 9:57
- Also relevant docs: facebook.github.io/react/docs/forms.html – ctrlplusb Commented Oct 4, 2016 at 9:58
- @ctrlplusb yes I was looking into that, but I thought maybe there was a way to get value in handleChange event – Sireini Commented Oct 4, 2016 at 10:11
1 Answer
Reset to default 7var App = React.createClass({
getInitialState: function() {
return {
text: "",
};
},
handleChange: function(event) {
this.setState({ text: event.target.value });
},
render() {
return <div>
<h1>Hello, {this.props.name}</h1>
<input type="text" onChange={this.handleChange} />
<p>{this.state.text}</p>
</div>;
},
});
You must store all state of the ponent in this.state
. Use this.setState
to update the state. When you update the state, the ponent is automatically rerendered with the new state.
The content of the paragraph is the current value of the state. onChange
is monly used instead of onKeyUp
to handle changes of state in text inputs. handleChange
will update the state when the text input changes.
本文标签: javascriptReactJs Print value instantlyStack Overflow
版权声明:本文标题:javascript - ReactJs Print value instantly - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743698983a2523990.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论