useQueryStates
How to read & update multiple search params at once
Multiple updates (batching)
You can call as many state update functions as needed in a single event loop tick, and they will be applied to the URL asynchronously:
If you wish to know when the URL has been updated, and what it contains, you can await the Promise returned by the state updater function, which gives you the updated URLSearchParameters object:
Implementation details (Promise caching)
The returned Promise is cached until the next flush to the URL occurs, so all calls to a setState (of any hook) in the same event loop tick will return the same Promise reference.
Due to throttling of calls to the Web History API, the Promise may be cached for several ticks. Batched updates will be merged and flushed once to the URL. This means not every setState will reflect to the URL, if another one comes overriding it before flush occurs.
The returned React state will reflect all set values instantly, to keep UI responsive.
useQueryStates
For query keys that should always move together, you can use useQueryStates
with an object containing each key’s type:
Options
There are three places you can define options in useQueryStates
:
- As the second argument to the hook itself (global options, like
history: 'push'
above) - On each parser, like
parseAsFloat.withOptions({ shallow: false })
- At the call level when updating the state:
The order of precedence is: call-level options > parser options > global options.
Tip
You can clear all keys managed by a useQueryStates
hook by passing
null
to the state updater function.
This will clear lat
& lng
, and leave other search params untouched.
Shorter search params keys
One issue with tying the parsers object keys to the search params keys was that you had to trade-off between variable names that make sense for your domain or business logic, and short, URL-friendly keys.
In nuqs@1.20.0
and later, you can use a urlKeys
object in the hook options
to remap the variable names to shorter keys:
As your application grows, you may want to reuse these parsers and urlKeys definitions across multiple components or nuqs features (like loaders or a serializer).
You can use the UrlKeys
type helper for this: