首页 > 解决方案 > 通过客户端导航到 nuxt 错误页面?

问题描述

当我使用 nuxt 部署通用应用程序时,我注意到抛出异常的客户端 $axios 请求只是将错误代码返回到控制台。有没有办法让 nuxt 重定向到我们在 layouts 文件夹中指定的 error.vue?我似乎只能通过调用context.error服务器端的方法来访问此页面。

我一直在接近它如下:

async submit (evt) {
  try {
    const { data } = await this.$axios.get(`some/url`)
    ...
  } catch (e) {
    throw new Error(e) // assume, for the sake of argument, that the error is: { 'statusCode': 403, 'message': 'Forbidden' }
  }
}

标签: vue.jsaxiosnuxt.jsvue-router

解决方案


在您的catch您可以通过以下方式将用户重定向到错误页面

    return this.$nuxt.error({ statusCode: 404, message: 'err message' })

在您的error.vue页面中,您可以使用error以下道具访问它:

<h1>{{ error.statusCode }}</h1>
<h2>{{ error.message }} </h2>

推荐阅读