softare development

Disable Button on Empty Input in React JS

In a React application, you can achieve the same functionality of disabling a button when an input is empty using React state and event handling.

1. Create a New React Application

The first thing we have to do is to create our React application using the command:

npx create-react-app folder-name

2. Add Bootstrap Styling

We’re also going to add a little Bootstrap for ease of design. We will add the following code to our index.html file in the public folder of our application.

  <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.1/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-4bw+/aepP/YC94hEpVNVgiZdgIC5+VKNBQNGCHeKRQN+PtmoHDEXuppvnDJzQIu9" crossorigin="anonymous">

Next, we will modify our App.js file as follows:

import React, { Component } from 'react';

class App extends Component{
  render(){
    return(
  <div className="container">
  <form>
  <div class="mb-3 col-md-6">
  <label for="exampleFormControlInput1" class="form-label">Email address</label>
  <input onChange={(e) => this.getValue(e)} type="email" class="form-control mb-4" placeholder="name@example.com" />
  <button type="button" class="form-control btn btn-primary btn-lg">Submit</button>
</div>
</form>
      </div>
    )
  }
}

export default App;

3. Set Initial State of Application

We need to set initial state for our application. What we want is that as the application loads initially, let the button be disabled and then we can conditionally check for input.

We will set the state as follows:

constructor(props){
    super(props);
    this.state = {
      isDisabled: false,
      email: ''
    }
  }

Next, we need to set that state in our button element.

render(){
    const { isDisabled } = this.state;
    return(
  <div className="container">
  <form>
  <div class="mb-3 col-md-6">
  <label for="exampleFormControlInput1" class="form-label">Email address</label>
  <input type="email" class="form-control mb-4" placeholder="name@example.com" />
  <button disabled={isDisabled} type="button" class="form-control btn btn-primary btn-lg">Submit</button>
</div>
</form>
      </div>
    )
  }

4. Create a Function that Gets the Entered Value

Finally, we’re going to create a function that gets the entered value and updates the state.

  getValue = (e) => {
    if(e.target.value === ""){
      this.setState({ isDisabled: true })
    }else {
      this.setState({ isDisabled: false })
    }
  }

Full Code Here

import React, { Component } from 'react';

class App extends Component{

  constructor(props){
    super(props);
    this.state = {
      isDisabled: true,
      email: ''
    }
  }

  getValue = (e) => {
    if(e.target.value === ""){
      this.setState({ isDisabled: true })
    }else {
      this.setState({ isDisabled: false })
    }
  }

  render(){
    const { isDisabled } = this.state;
    return(
  <div className="container">
  <form>
  <div class="mb-3 col-md-6">
  <label for="exampleFormControlInput1" class="form-label">Email address</label>
  <input onChange={(e) => this.getValue(e)} type="email" class="form-control mb-4" placeholder="name@example.com" />
  <button disabled={isDisabled} type="button" class="form-control btn btn-primary btn-lg">Submit</button>
</div>
</form>
      </div>
    )
  }
}

export default App;

Result

Buy Mobile App Templates

Share
Published by
codeflare

Recent Posts

C++ Queue

1. What Is a Queue? A Queue is a linear data structure that follows the principle: FIFO – First…

8 hours ago

Must-Know Angular Concepts

Angular is a full-featured frontend framework built by Google for creating large, maintainable, and high-performance web applications.…

2 days ago

Responsive Web Design (RWD)

What Is Responsive Web Design? Responsive Web Design (RWD) is an approach to building websites…

2 days ago

Geolocation API in JavaScript

The Geolocation API allows a web application to access a user’s geographical location (latitude, longitude, and more), with…

1 week ago

The Golden Ratio (φ)

1. What Is the Golden Ratio? The Golden Ratio, represented by the Greek letter φ (phi), is…

2 weeks ago

CSS Combinators

In CSS, combinators define relationships between selectors. Instead of selecting elements individually, combinators allow you to target elements based…

3 weeks ago