What I want to do is when I type some text in an input field, it should appear in another place realtime.
Below is my input;
<div className="post_input"> <input className='post_data_input_overlay' placeholder="Ask your question here" ref="postTxt"/> </div>
How can I achieve that?
If you want to understand React to its core, you should read along. It's a one-way road for the data. React apps are made up of carefully organized components. These components receive arguments(props) and return information using the return value of the render function.
Data Binding: Angular vs. React. In short, Angular uses two-way (bi-directional) data binding while React uses one-way (unidirectional) data binding computations. For AngularJS, this means that changing a UI element will also change the corresponding model's state as well.
Two-way binding — implicitly enforcing that some value in the DOM is always consistent with some React state — is concise and supports a wide variety of applications.
ReactJS bind() Method The bind() is an inbuilt method in React that is used to pass the data as an argument to the function of a class based component.
Data binding in React can be achieved by using a controlled input
. A controlled input is achieved by binding the value to a state variable
and a onChange
event to change the state as the input value changes.
See the below snippet
class App extends React.Component { constructor() { super(); this.state = { value: 'Hello World' }; } handleChange = (e) => { this.setState({ value: e.target.value }); }; render() { return ( <div> <input type="text" value={this.state.value} onChange={this.handleChange} /> <p>{this.state.value}</p> </div> ); } } ReactDOM.render(<App />, document.getElementById('app'));
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react-dom.js"></script> <div id="app"></div>
Here is an equivalent function component of the class defined above.
const { useState } = React; const App = () => { const [value, setValue] = useState('Hello World'); const handleChange = (e) => setValue(e.target.value); return ( <div> <input type="text" value={value} onChange={handleChange} /> <p>{value}</p> </div> ); }; ReactDOM.render(<App />, document.getElementById('app'));
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.14.0/umd/react.production.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.14.0/umd/react-dom.production.min.js"></script> <div id="app"></div>
To be short, in React, there's no two-way data-binding.
So when you want to implement that feature, try define a state
, and write like this, listening events, update the state, and React renders for you:
class NameForm extends React.Component { constructor(props) { super(props); this.state = {value: ''}; this.handleChange = this.handleChange.bind(this); } handleChange(event) { this.setState({value: event.target.value}); } render() { return ( <input type="text" value={this.state.value} onChange={this.handleChange} /> ); } }
Details here https://facebook.github.io/react/docs/forms.html
UPDATE 2020
Note:
LinkedStateMixin is deprecated as of React v15. The recommendation is to explicitly set the value and change handler, instead of using LinkedStateMixin.
above update from React official site . Use below code if you are running under v15 of React else don't.
There are actually people wanting to write with two-way binding, but React does not work in that way. If you do want to write like that, you have to use an addon for React, like this:
var WithLink = React.createClass({ mixins: [LinkedStateMixin], getInitialState: function() { return {message: 'Hello!'}; }, render: function() { return <input type="text" valueLink={this.linkState('message')} />; } });
Details here https://facebook.github.io/react/docs/two-way-binding-helpers.html
For refs
, it's just a solution that allow developers to reach the DOM in methods of a component, see here https://facebook.github.io/react/docs/refs-and-the-dom.html
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With