mirror of
https://github.com/nuxt/nuxt.git
synced 2024-11-15 18:34:50 +00:00
dc47c64f14
Co-authored-by: Daniel Roe <daniel@roe.dev> Co-authored-by: Sébastien Chopin <seb@nuxtjs.com> Co-authored-by: Pooya Parsa <pooya@pi0.io> Co-authored-by: pooya parsa <pyapar@gmail.com> Co-authored-by: Clément Ollivier <clement.o2p@gmail.com>
67 lines
3.1 KiB
Markdown
67 lines
3.1 KiB
Markdown
---
|
|
title: "useRouter"
|
|
description: "The useRouter composable returns the router instance."
|
|
---
|
|
|
|
# `useRouter`
|
|
|
|
The useRouter composable returns the router instance and must be called in a setup function, plugin, or route middleware.
|
|
|
|
Within the template of a Vue component, you can access the router using `$router` instead.
|
|
|
|
If you have a `pages/` folder, `useRouter` is identical in behavior to the one provided by `vue-router`. Feel free to read the router documentation for more information on what each method does.
|
|
|
|
::ReadMore{link="https://router.vuejs.org/api/#currentroute"}
|
|
::
|
|
|
|
## Basic Manipulation
|
|
|
|
- **addRoute:** Add a new route to the router instance. `parentName` can be provided to add new route as the child of an existing route.
|
|
- **removeRoute:** Remove an existing route by its name.
|
|
- **getRoutes:** Get a full list of all the route records.
|
|
- **hasRoute:** Checks if a route with a given name exists.
|
|
|
|
## Based on History API
|
|
|
|
- **back:** Go back in history if possible, same as `router.go(-1)`.
|
|
- **forward:** Go forward in history if possible, same as `router.go(1)`.
|
|
- **go:** Move forward or backward through the history without the hierarchical restrictions enforced in `router.back()` and `router.forward()`.
|
|
- **push:** Programmatically navigate to a new URL by pushing an entry in the history stack. **It is recommended to use [`navigateTo`](http://v3.nuxtjs.org/api/utils/navigate-to) instead.**
|
|
- **replace:** Programmatically navigate to a new URL by replacing the current entry in the routes history stack. **It is recommended to use [`navigateTo`](http://v3.nuxtjs.org/api/utils/navigate-to) instead.**
|
|
|
|
> TIP: `router.addRoute()` adds route details into an array of routes and it is useful while building Nuxt plugins while `router.push()` on the other hand, triggers a new navigation immediately and it is useful in Nuxt Page components, Vue components and composable.
|
|
|
|
```js [js]
|
|
const router = useRouter();
|
|
router.back();
|
|
router.forward();
|
|
router.go();
|
|
router.push({ path: "/home" });
|
|
router.replace({ hash: "#bio" });
|
|
````
|
|
|
|
::ReadMore{link="https://developer.mozilla.org/en-US/docs/Web/API/History"}
|
|
::
|
|
|
|
## Navigation Guards
|
|
|
|
`useRouter` composable provides `afterEach`, `beforeEach` and `beforeResolve` helper methods that acts as nagivation guards.
|
|
|
|
However, Nuxt has a concept of **route middleware** that simplifies the implementation of navigation guards and provides a better developer experience.
|
|
|
|
::ReadMore{link="/guide/directory-structure/middleware"}
|
|
::
|
|
|
|
## Promise and Error Handling
|
|
|
|
- **isReady:** Returns a Promise that resolves when the router has completed the initial navigation.
|
|
- **onError:** Adds an error handler that is called every time a non caught error happens during navigation.
|
|
- **resolve:** Returns the normalized version of a route location. Also includes an `href` property that includes any existing base.
|
|
|
|
::ReadMore{link="https://router.vuejs.org/api/#router-methods"}
|
|
::
|
|
|
|
## Universal Router Instance
|
|
|
|
If you do not have a `pages/` folder, then `useRouter` will return a universal router instance with similar helper methods, but be aware that not all features may be supported or behave in exactly the same way as with `vue-router`.
|