# react/no-did-mount-set-state
📝 Disallow usage of setState in componentDidMount.
Updating the state after a component mount will trigger a second `render()` call and can lead to property/layout thrashing.
## Rule Details
This rule is aimed to forbid the use of `this.setState` in `componentDidMount` outside of functions, such as callbacks.
Examples of **incorrect** code for this rule:
```jsx
var Hello = createReactClass({
componentDidMount: function() {
this.setState({
name: this.props.name.toUpperCase()
});
},
render: function() {
return
Hello {this.state.name}
;
}
});
```
Examples of **correct** code for this rule:
```jsx
var Hello = createReactClass({
componentDidMount: function() {
this.onMount(function callback(newName) {
this.setState({
name: newName
});
});
},
render: function() {
return Hello {this.state.name}
;
}
});
```
```jsx
var Hello = createReactClass({
componentDidMount: function() {
this.props.onMount();
},
render: function() {
return Hello {this.props.name}
;
}
});
```
## Rule Options
```js
...
"react/no-did-mount-set-state": [, ]
...
```
### `disallow-in-func` mode
By default this rule forbids any call to `this.setState` in `componentDidMount` outside of functions. The `disallow-in-func` mode makes this rule more strict by disallowing calls to `this.setState` even within functions.
Examples of **incorrect** code for this rule:
```jsx
var Hello = createReactClass({
componentDidMount: function() {
this.setState({
name: this.props.name.toUpperCase()
});
},
render: function() {
return Hello {this.state.name}
;
}
});
```
```jsx
var Hello = createReactClass({
componentDidMount: function() {
this.onMount(function callback(newName) {
this.setState({
name: newName
});
});
},
render: function() {
return Hello {this.state.name}
;
}
});
```