Warns you if you have defined a prop type but it is never being used anywhere.
The following patterns are considered warnings:
var Hello = createReactClass({
propTypes: {
name: PropTypes.string
},
render: function() {
return <div>Hello Bob</div>;
}
});
var Hello = createReactClass({
propTypes: {
firstname: PropTypes.string.isRequired,
middlename: PropTypes.string.isRequired, // middlename is never used below
lastname: PropTypes.string.isRequired
},
render: function() {
return <div>Hello {this.props.firstname} {this.props.lastname}</div>;
}
});
The following patterns are not considered warnings:
var Hello = createReactClass({
propTypes: {
name: PropTypes.string
},
render: function() {
return <div>Hello {this.props.name}</div>;
}
});
This rule can take one argument to ignore some specific props during validation.
...
"react/no-unused-prop-types": [<enabled>, { customValidators: <customValidator>, skipShapeProps: <skipShapeProps> }]
...
enabled
: for enabling the rule. 0=off, 1=warn, 2=error. Defaults to 0.customValidators
: optional array of validators used for propTypes validation.skipShapeProps
: In some cases it is impossible to accurately detect whether or not aPropTypes.shape
's values are being used. Setting this option totrue
will skip validation ofPropTypes.shape
(true
by default).
For components with Stateless Functional Components (often used as helper render methods); SFC is a function that takes prop(s) as an argument and returns a JSX expression. Even if this function gets called from a component the props that are only used inside SFC would not be considered used by a component.
Triggers false positive:
function AComponent(props) {
function helperRenderer(aProp) { // is considered SFC
return (
<span>{aProp}{props.bProp}</span>
);
}
return (
<div>
{helperRenderer(props.aProp)}
</div>
);
}
AComponent.propTypes = {
aProp: PropTypes.string,
bProp: PropTypes.string // bProp is defined but never used
};
A suggested fix is to assign a bProp to a variable outside of the SFC.
function AComponent(props) {
const { bProp } = props
function helperRenderer(aProp) { // is considered SFC
return (
<span>{aProp}{bProp}</span>
);
}
return (
<div>
{helperRenderer(props.aProp)}
</div>
);
}
AComponent.propTypes = {
aProp: PropTypes.string,
bProp: PropTypes.string
};
when assigning a part or a whole props object to a variable and using it to access a prop value.
class AComponent extends React.Component {
render() {
const { props } = this;
return <div>{props.aProp}</div>;
}
}
AComponent.propTypes = {
aProp: PropTypes.string // aProp PropType is defined but prop is never used
};
suggested code structure to avoid the issue:
- accessing prop directly
class AComponent extends React.Component {
render() {
return <div>{this.props.aProp}</div>;
}
}
AComponent.propTypes = {
aProp: PropTypes.string
};
- or assigning a final prop to a variable.
class AComponent extends React.Component {
const { aProp } = this.props;
render() {
return <div>{aProp}</div>;
}
}
AComponent.propTypes = {
aProp: PropTypes.string
};
Using Intermediate variables might be desired and unavoidable for more complex props structure.
Like for shape prop types. To avoid false positive in this case make sure skipShapeProps
is set to true
.