error.vue
error.vue 文件是你的 Nuxt 应用中的错误页面。
在应用程序的生命周期中,某些错误可能会在运行时意外出现。在这种情况下,我们可以使用 error.vue
文件覆盖默认的错误文件,并以友好的方式显示错误。
error.vue
<script setup lang="ts">
import type { NuxtError } from '#app'
const props = defineProps({
error: Object as () => NuxtError
})
</script>
<template>
<div>
<h1>{{ error.statusCode }}</h1>
<NuxtLink to="/">返回首页</NuxtLink>
</div>
</template>
尽管它被称为“错误页面”,但它不是一个路由文件,因此不应放置在你的
~/pages
目录下。出于同样的原因,你也不应在该页面内使用 definePageMeta
。话虽如此,你仍然可以通过使用 NuxtLayout
组件并指定布局名称,在错误文件中使用布局。错误页面只有一个 prop —— error
,它包含了供你处理的错误信息。
error
对象包含以下字段:
{
statusCode: number
fatal: boolean
unhandled: boolean
statusMessage?: string
data?: unknown
cause?: unknown
}
如果你的错误中有自定义字段,它们将会丢失;你应该将它们赋值给 data
:
throw createError({
statusCode: 404,
statusMessage: '页面未找到',
data: {
myCustomField: true
}
})