# react/prefer-stateless-function 📝 Enforce stateless components to be written as a pure function. Stateless functional components are simpler than class based components and will benefit from future React performance optimizations specific to these components. ## Rule Details This rule will check your class based React components for - methods/properties other than `displayName`, `propTypes`, `contextTypes`, `defaultProps`, `render` and useless constructor (same detection as `eslint` [no-useless-constructor rule](https://eslint.org/docs/rules/no-useless-constructor)) - instance property other than `this.props` and `this.context` - extension of `React.PureComponent` (if the `ignorePureComponents` flag is true) - presence of `ref` attribute in JSX - the use of decorators - `render` method that return anything but JSX: `undefined`, `null`, etc. (only in React <15.0.0, see [shared settings](https://github.com/jsx-eslint/eslint-plugin-react/blob/master/README.md#configuration) for React version configuration) If none of these elements are found, the rule will warn you to write this component as a pure function. Examples of **incorrect** code for this rule: ```jsx var Hello = createReactClass({ render: function() { return