Optimizing React Form State with Constate
/ 1 min read
I worked on optimizing some React form state management: From a full rerender with ~15ms on every keystroke down to ~3ms thanks to constate lib. Nice thing about constate: It just picks up custom hooks you might already have, it doesn’t feel like a whole different lib to be picked up like Redux.
constate is a helper that abstracts away creating multiple contexts and related custom hooks to subscribe the updates. This allows you to circumvent the problem of full state updates when managing state in a single context. As I said above, the way you write React doesn’t change much, it doesn’t feel like you need to buy in to another external state management lib.
Here’s the PR with a more detailed description for Kibana that includes that update: https://github.com/elastic/kibana/pull/149670
Before the update, everything would update, visible in the Chrome Dev Tools Flame Graph because everything is colored:
data:image/s3,"s3://crabby-images/7e644/7e6447fbf8505f83b575a6c823b8ec4446d5a914" alt="Screenshot of Chrome Dev Tools Flame Graph before state management update"
When rendering with the update, the gray areas indicate that the full form is no longer rerendered on every keystroke but just the elements that have been touched.
data:image/s3,"s3://crabby-images/973f3/973f3ba04d0b2445570151540d24e0bbfccdae97" alt="Screenshot of Chrome Dev Tools Flame Graph after state management update"