App Router Hooks
These hooks are available as of Solito v4. They will only work in the Next.js
app
directory on the Web side.
useRouter
​
ts
'use client'import { useRouter } from 'solito/navigation'export function MyClientComponent() {const router = useRouter()const onPress = () => {router.push('/users/fernando')// or replacerouter.replace('/users/fernando')// or go backrouter.back()}}
ts
'use client'import { useRouter } from 'solito/navigation'export function MyClientComponent() {const router = useRouter()const onPress = () => {router.push('/users/fernando')// or replacerouter.replace('/users/fernando')// or go backrouter.back()}}
useParams
​
100% feature parity with the Next.js hook.
tsx
'use client'import { useParams } from 'solito/navigation'type Params = { tag: string; item: string }export default function ExampleClientComponent() {const params = useParams<Params>()// Route -> /shop/[tag]/[item]// URL -> /shop/shoes/nike-air-max-97// `params` -> { tag: 'shoes', item: 'nike-air-max-97' }console.log(params)return <></>}
tsx
'use client'import { useParams } from 'solito/navigation'type Params = { tag: string; item: string }export default function ExampleClientComponent() {const params = useParams<Params>()// Route -> /shop/[tag]/[item]// URL -> /shop/shoes/nike-air-max-97// `params` -> { tag: 'shoes', item: 'nike-air-max-97' }console.log(params)return <></>}
If you want to reuse the types, and you're using a sufficiently-recent version of TypeScript, you can create a custom function with the wrapped type:
ts
import { useParams } from 'solito/navigation'type Params = { tag: string; item: string }export const useShoppingParams = useParam<Params>// then in your component:const params = useShoppingParams()
ts
import { useParams } from 'solito/navigation'type Params = { tag: string; item: string }export const useShoppingParams = useParam<Params>// then in your component:const params = useShoppingParams()
useSearchParams
​
100% feature parity with the Next.js hook.
tsx
'use client'import { useSearchParams } from 'solito/navigation'type Params = { search: string }export default function ExampleClientComponent() {const params = useSearchParams<Params>()const search = searchParams.get('search')// URL -> `/dashboard?search=my-project`// `search` -> 'my-project'return <></>}
tsx
'use client'import { useSearchParams } from 'solito/navigation'type Params = { search: string }export default function ExampleClientComponent() {const params = useSearchParams<Params>()const search = searchParams.get('search')// URL -> `/dashboard?search=my-project`// `search` -> 'my-project'return <></>}
usePathname
​
100% feature parity with the Next.js hook.
ts
'use client'import { usePathname } from 'solito/navigation'export default function ExampleClientComponent() {const pathname = usePathname()// /dashboard?search=hi// pathname is /dashboardreturn <>Current pathname: {pathname}</>}
ts
'use client'import { usePathname } from 'solito/navigation'export default function ExampleClientComponent() {const pathname = usePathname()// /dashboard?search=hi// pathname is /dashboardreturn <>Current pathname: {pathname}</>}
Please keep in mind that this hook may not be perfectly safe to use on iOS / Android if you haven't gone all-in on using links to power navigation for React Navigation. If all screens have a linking config, then this should be safe. Expo Router users can use this hook safely.
I am looking into adding support for usePathname
for solito/router
too, allowing its usage in non-App Router folders.
useUpdateSearchParams
​
A Solito hook to update search parameters.
tsx
'use client'type Params = {id: string}export function App() {const updateParams = useUpdateSearchParams<Params>()const onPress = () => {updateParams({ id: '123' })// by default, router.replace is called on Web if you're updating an existing param// to override this, see the webBehavior propertyupdateParams({ id: '123' }, { webBehavior: 'push' })}}
tsx
'use client'type Params = {id: string}export function App() {const updateParams = useUpdateSearchParams<Params>()const onPress = () => {updateParams({ id: '123' })// by default, router.replace is called on Web if you're updating an existing param// to override this, see the webBehavior propertyupdateParams({ id: '123' }, { webBehavior: 'push' })}}
On native, setParams
is called. On Web, it either uses push
or replace
.