编程语言
547
useRouter 钩子允许你在 客户端组件 中以编程方式更改路由。
推荐: 除非有特定需求使用
useRouter,否则建议使用<Link>组件进行导航。
// app/example-client-component.tsx 'use client' import { useRouter } from 'next/navigation' export default function Page() { const router = useRouter() return ( <button type="button" onClick={() => router.push('/dashboard')}> Dashboard </button> ) }
useRouter()
-
router.push(href: string, { scroll: boolean }): 执行客户端导航到指定路由,在浏览器的历史记录堆栈中添加新条目。 -
router.replace(href: string, { scroll: boolean }): 执行客户端导航到指定路由,但不在浏览器的历史记录堆栈中添加新条目。 -
router.refresh(): 刷新当前路由,向服务器发起新请求,重新获取数据并重新渲染服务端组件。客户端将合并更新的 React 服务端组件内容而不丢失未受影响的客户端 React 状态(如useState)或浏览器状态(如滚动位置)。 -
router.prefetch(href: string): 为更快的客户端过渡预取指定路由。 -
router.back(): 导航回浏览器历史记录堆栈中的上一条路由。 -
router.forward(): 导航到浏览器历史记录堆栈中的下一页。
值得注意的是:
<Link>组件在进入视口时会自动预取路由。- 如果请求被缓存,
refresh()可能会重新产生相同的结果。其他动态功能,如cookies和headers也可能改变响应。
从 next/router 迁移
- 在使用应用路由器时,
useRouter钩子应从next/navigation导入,而不是从next/router导入。 -
pathname字符串已被移除,替代为usePathname()。 -
query对象已被移除,替代为useSearchParams()。 -
router.events已被替代。参见下方。
示例
路由事件
你可以通过组合其他客户端组件钩子(如 usePathname 和 useSearchParams)来监听页面更改。
// app/components/navigation-events.js 'use client' import { useEffect } from 'react' import { usePathname, useSearchParams } from 'next/navigation' export function NavigationEvents() { const pathname = usePathname() const searchParams = useSearchParams() useEffect(() => { const url = `${pathname}?${searchParams}` console.log(url) // 你现在可以使用当前 URL // ... }, [pathname, searchParams]) return '...' }
可以将其导入到布局中。
// app/layout.js import { Suspense } from 'react' import { NavigationEvents } from './components/navigation-events' export default function Layout({ children }) { return ( <html lang="en"> <body> {children} <Suspense fallback={null}> <NavigationEvents /> </Suspense> </body> </html> ) }
值得注意的是:
<NavigationEvents>被包裹在一个Suspense边界中,因为useSearchParams()在静态渲染期间导致最接近的Suspense边界触发客户端渲染。了解更多。
禁用滚动恢复
默认情况下,Next.js 在导航到新路由时会滚动到页面顶部。你可以通过将 scroll: false 传递给 router.push() 或 router.replace() 来禁用此行为。
// app/example-client-component.tsx 'use client' import { useRouter } from 'next/navigation' export default function Page() { const router = useRouter() return ( <button type="button" onClick={() => router.push('/dashboard', { scroll: false })}> Dashboard </button> ) }
版本历史
| 版本 | 变更 |
|---|---|
v13.0.0 |
useRouter 从 next/navigation 中引入。 |