mirror of
https://github.com/nuxt/nuxt.git
synced 2024-12-01 18:07:22 +00:00
90784f79d7
* docs: implement new website theme * chore: rename dirs * chore: update build * lint fix * chore: update deps * fix: include node_modules in esbuild step * chore: update deps * Update .gitignore * chore: update theme version * up * up * fix: use svg for illustration * chore: update to 0.0.12 * chore: force parse5 resolution * stay with build * feat: always display first home section * Update yarn.lock * chore: update theme * fix lint * docs: update home title * chore: update website theme version * Update docs/content/0.index.md Co-authored-by: pooya parsa <pyapar@gmail.com> * Update docs/content/0.index.md Co-authored-by: pooya parsa <pyapar@gmail.com> * up * chore: bump theme version * up * chore: up * up up and up * chore: generate * fix: boolean value * feat: new images * update again * chore: up * ouep * chore: up Co-authored-by: Daniel Roe <daniel@roe.dev> Co-authored-by: Clément Ollivier <clement.o2p@gmail.com> Co-authored-by: pooya parsa <pyapar@gmail.com>
64 lines
2.0 KiB
Markdown
64 lines
2.0 KiB
Markdown
---
|
||
title: "defineNuxtRouteMiddleware"
|
||
---
|
||
|
||
# `defineNuxtRouteMiddleware`
|
||
|
||
Create named route middleware using `defineNuxtRouteMiddleware` helper function.
|
||
|
||
Route middleware are stored in the `middleware/` directory of your Nuxt application (unless [set otherwise](/docs/api/configuration/nuxt-config#middleware)).
|
||
|
||
## Type
|
||
|
||
```ts
|
||
defineNuxtRouteMiddleware(middleware: RouteMiddleware) => RouteMiddleware
|
||
|
||
interface RouteMiddleware {
|
||
(to: RouteLocationNormalized, from: RouteLocationNormalized): ReturnType<NavigationGuard>
|
||
}
|
||
```
|
||
|
||
## Parameters
|
||
|
||
### `middleware`
|
||
|
||
- **Type**: `RouteMiddleware`
|
||
|
||
A function that takes two Vue Router's route location objects as parameters: the next route `to` as the first, and the current route `from` as the second.
|
||
|
||
Learn more about available properties of `RouteLocationNormalized` in the **[Vue Router docs](https://router.vuejs.org/api/interfaces/RouteLocationNormalized.html)**.
|
||
|
||
## Examples
|
||
|
||
### Showing Error Page
|
||
|
||
You can use route middleware to throw errors and show helpful error messages:
|
||
|
||
```ts [middleware/error.ts]
|
||
export default defineNuxtRouteMiddleware((to) => {
|
||
if (to.params.id === '1') {
|
||
throw createError({ statusCode: 404, statusMessage: 'Page Not Found' })
|
||
}
|
||
})
|
||
```
|
||
|
||
The above route middleware will redirect a user to the custom error page defined in the `~/error.vue` file, and expose the error message and code passed from the middleware.
|
||
|
||
### Redirection
|
||
|
||
Use `useState` in combination with `navigateTo` helper function inside the route middleware to redirect users to different routes based on their authentication status:
|
||
|
||
```ts [middleware/auth.ts]
|
||
export default defineNuxtRouteMiddleware((to, from) => {
|
||
const auth = useState('auth')
|
||
|
||
if (!auth.value.isAuthenticated) {
|
||
return navigateTo('/login')
|
||
}
|
||
|
||
return navigateTo('/dashboard')
|
||
})
|
||
```
|
||
|
||
Both [navigateTo](/docs/api/utils/navigate-to) and [abortNavigation](/docs/api/utils/abort-navigation) are globally available helper functions that you can use inside `defineNuxtRouteMiddleware`.
|