React Props Data Type Validation: In React, PropTypes are a way to specify and validate the expected data types of the props (short for “properties”) that a component should receive.
They are a part of React’s type checking and help catch potential bugs and improve code quality. PropTypes are especially useful in large and complex applications where it’s important to ensure that the data being passed between components is of the correct type.
You can validate props data using the following ways
- PropTypes Library
- Custom PropTypes
How to use PropType
Import PropTypes
To use PropTypes, you first need to import them from the prop-types library. Starting from React 15.5, PropTypes have been moved out of the React core into a separate package, so you need to install it and import it into your component files.
import PropTypes from 'prop-types';
Defining PropTypes
You can define the PropTypes for a component by adding a propTypes property to the component class or functional component.
class MyComponent extends React.Component {
  // Define propTypes
  static propTypes = {
    name: PropTypes.string,
    age: PropTypes.number,
    isStudent: PropTypes.bool,
  };
  // ...
}
For functional components (using the function declaration or arrow function syntax):
function MyComponent(props) {
  // ...
}
MyComponent.propTypes = {
  name: PropTypes.string,
  age: PropTypes.number,
  isStudent: PropTypes.bool,
};
Specifying Prop Types
You can use various PropTypes to specify the expected data types for your props. Some commonly used PropTypes include
- PropTypes.string: Expects a string.
- PropTypes.number: Expects a number.
- PropTypes.bool: Expects a boolean.
- PropTypes.array: Expects an array.
- PropTypes.object: Expects an object.
- PropTypes.func: Expects a function.
- PropTypes.element: Expects a React element.
- PropTypes.node: Expects any renderable content (string, number, element, etc.).
Default Prop Values
You can also set default values for props using the defaultProps property. This ensures that if a prop is not provided, the default value will be used instead.
MyComponent.defaultProps = {
  name: 'John Doe',
  age: 30,
  isStudent: false,
};
Validate Props using PropType
You have seen in the previous steps how to use propType. now, let’s see its complete code to validate props data types.
import React from 'react';
import PropTypes from 'prop-types';
function MyComponent(props) {
  return (
    <div>
      <h1>Hello, {props.name}</h1>
      <p>Age: {props.age}</p>
      <p>Is Student? {props.isStudent ? 'Yes' : 'No'}</p>
    </div>
  );
}
// Define PropTypes for MyComponent
MyComponent.propTypes = {
  name: PropTypes.string.isRequired, // A required string prop
  age: PropTypes.number,            // An optional number prop
  isStudent: PropTypes.bool       // An optional boolean prop
};
// Default prop values (optional)
MyComponent.defaultProps = {
  age: 30,
  isStudent: false
};
function App() {
  return (
    <div>
      <MyComponent name="John Doe" age={25} isStudent={true} />
      <MyComponent name="Alice" />
    </div>
  );
}
export default App;
Explanation
Step-1: We define a functional component named MyComponent that takes name, age, and isStudent as props and renders them.
Step-2: Inside the MyComponent function, we define PropTypes using the propTypes property. Just like in class components, we specify that the name prop is required (using .isRequired), age is optional, and isStudent is also optional.
Step-3: We provide default values for age and isStudent using the defaultProps property. If these props are not provided, the default values will be used.
Step-4: In the App component, we use MyComponent twice, passing different prop values. One instance has all props specified, and the other instance doesn’t provide the age and isStudent props, which is fine because they have default values
Validate Props using Custom PropType
Custom PropTypes in React allow you to define your own validation rules for the props passed to a component. While React provides built-in PropTypes for common data types, you can create custom
PropTypes to ensure that props meet specific requirements or constraints that are not covered by the standard PropTypes. This can be particularly useful when you need more fine-grained control over the validation of your component’s props
import React from 'react';
import PropTypes from 'prop-types';
// Custom PropTypes validator
function customStringPropValidator(props, propName, componentName) {
  if (!props[propName]) {
    return new Error(`The prop '${propName}' is required.`);
  }
  if (typeof props[propName] !== 'string') {
    return new Error(`Invalid prop type for '${propName}'. It should be a string.`);
  }
}
// React component with custom PropTypes
class MyComponent extends React.Component {
  render() {
    return (
      <div>
        <p>Custom String Prop: {this.props.customStringProp}</p>
      </div>
    );
  }
}
MyComponent.propTypes = {
  customStringProp: customStringPropValidator,
};
function App() {
  return <MyComponent customStringProp="Hello, World!" />;
}
export default App;
Step-1: We define a custom PropTypes validator function called customStringPropValidator. This function checks that the prop is not empty and is of type string.
Step-2: We attach the custom PropTypes validator to the customStringProp prop in the MyComponent component’s propTypes object.
Step-3: In the App component, we use MyComponent and pass the customStringProp with a valid string value. If you change the value to an empty string or a non-string type, you will see a warning in the console during development.
