EN
React - optimal way to create state
3 points
In this article, we would like to show you optimal way to create state in React.
When creating initial state in a component needs some complex operations we should pass an arrow function as React.useState
argument instead of just passing an object.
This approach prevents from doing complex operations every time component re-renders with the same value.
In our case we prevent parsing jsonOrData
with every App
re-render just by passing an arrow function as useState
argument.
Good approach:
xxxxxxxxxx
1
const [data, setData] = React.useState(() => createData(jsonOrData));
Bad approach:
xxxxxxxxxx
1
const [data, setData] = React.useState(createData(jsonOrData));
Runnable example:
xxxxxxxxxx
1
// import React from 'react';
2
// import ReactDOM from 'react-dom';
3
4
const createData = (jsonOrData) => {
5
if (typeof jsonOrData === 'string') {
6
return JSON.parse(jsonOrData);
7
}
8
return jsonOrData;
9
};
10
11
const User = ({jsonOrData}) => {
12
// When state creation is heavy we sould use useState(() => ...)
13
const [data, setData] = React.useState(() => createData(jsonOrData));
14
// When state change is heavy we sould use useEffect(() => ..., [...])
15
React.useEffect(() => createData(jsonOrData), [jsonOrData]);
16
return (
17
<div>
18
{data.name} {data.age}
19
</div>
20
);
21
};
22
23
const App = () => {
24
const user = {
25
name: 'John',
26
age: 25,
27
// other properties here...
28
};
29
return (
30
<div>
31
<User jsonOrData={user} />
32
</div>
33
);
34
};
35
36
const root = document.querySelector('#root');
37
ReactDOM.render(<App />, root );