Categories: JavascriptWeb

ReactJS – Controlled Component Code Example

This article represents code sample for ReactJS UI controlled components along with related details. Please feel free to comment/suggest if I missed to mention one or more important points. Also, sorry for the typos.
The code sample represents an input field consisting of “Calvin”. Once you change the text, the “calvin” written with “Hello” would also change. Following are the key points described later in this article:
  • What are controlled components?
  • Code Example – Controlled Component
What are Controlled Component?

As per the ReactJS Form page, An <input> with “value” set is a controlled component. In a controlled <input>, the value of the rendered element will always reflect the value prop.

In the example below, the textfield consists of “value” attribute which is assigned to “this.state.value”. Following code represents the controlled component:

<input type="text" value={this.state.value} onChange={this.handleChange}/>
Code Example – Controlled Component

The code below represents following:

  • The controlled UI component, namely, <input> field with value set.
  • “onChange” event handler with a callback method “handleChange” which is invoked as the text in input field changes
  • “setState” function which is invoked from handleChange method, thereby setting the value of “value” field to changed value
  • “getInitialState” function setting the initial value of “value”

Changing text inside the text field will change the text ahead of “Hello”. Following screenshot represents the UI.

Following is the code sample:

<!DOCTYPE html>
<html>
<head>
<title>Hello ReactJS!</title>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/0.13.3/react.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/0.13.3/JSXTransformer.js"></script>
<link rel="stylesheet" type="text/css" href="http://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap.min.css">
</head>
<body class="container">
<div id="content"></div>
<script type="text/jsx"> 
 var HelloUI = React.createClass({
  getInitialState: function(){
   return {value: 'Calvin'};
  },
  handleChange: function(event) {
   this.setState({value: event.target.value});
  },
  render: function(){
   return(    
    <div>
    <h1>Hello, {this.state.value}</h1>
    <hr/>       
    <input type="text" value={this.state.value} onChange={this.handleChange}/>          
    </div>
    );
  }
 }); 
 React.render(<HelloUI />, document.getElementById("content"))
</script>
</body>
</html>
Hope the article was helpful in presenting concepts and code samples related with UI Controlled Component in ReactJS.
Ajitesh Kumar

I have been recently working in the area of Data analytics including Data Science and Machine Learning / Deep Learning. I am also passionate about different technologies including programming languages such as Java/JEE, Javascript, Python, R, Julia, etc, and technologies such as Blockchain, mobile computing, cloud-native technologies, application security, cloud computing platforms, big data, etc. For latest updates and blogs, follow us on Twitter. I would love to connect with you on Linkedin. Check out my latest book titled as First Principles Thinking: Building winning products using first principles thinking. Check out my other blog, Revive-n-Thrive.com

Share
Published by
Ajitesh Kumar

Recent Posts

Mean Squared Error vs Cross Entropy Loss Function

Last updated: 28th April, 2024 As a data scientist, understanding the nuances of various cost…

2 days ago

Cross Entropy Loss Explained with Python Examples

Last updated: 28th April, 2024 In this post, you will learn the concepts related to…

2 days ago

Logistic Regression in Machine Learning: Python Example

Last updated: 26th April, 2024 In this blog post, we will discuss the logistic regression…

3 days ago

MSE vs RMSE vs MAE vs MAPE vs R-Squared: When to Use?

Last updated: 22nd April, 2024 As data scientists, we navigate a sea of metrics to…

5 days ago

Gradient Descent in Machine Learning: Python Examples

Last updated: 22nd April, 2024 This post will teach you about the gradient descent algorithm…

1 week ago

Loss Function vs Cost Function vs Objective Function: Examples

Last updated: 19th April, 2024 Among the terminologies used in training machine learning models, the…

1 week ago