retep0214 2019-06-13 11:45 采纳率: 0%
浏览 893

Nuxt如何在SSR中指定错误页面?

我现在正在用Nuxt来开发一个网页、并配搭VueX和Axios来呼叫API提取数据。现在正在处理错误页面。

根据官方教学用layout/error.vue成功做出自定义的错误页
并可以使用this.$nuxt.error(".........")来把自定的错误信息扔进错误页。
错的URL也能进错误页
可是万一是在SSR时发生错误(API返回了500)
就一定会跳到预设的错误页面

以下是我的代码

VueX

./store/item.js

import myAxios from 'myAxios.js'

export const actions = {
  fetchItems: async ({ commit }) => {
    const items = await myAxois.get('https://jsonplaceholder.typicode.com/todos/1')
        if(items.data.status === "deleted"){
                // 发生错误跳到错误页
                // SSR时无法使用$nuxt.error
                // throw Error也会跳到预设页
        }else{
    commit('setItems', items.data)
        }
  },

Axios

myAxios.js

cpAxois.interceptors.response.use((response) => {

  return response
}, (error) => {

  const { response } = error
  const { status, statusText } = response
  if (process.client) {
    $nuxt.error({ message: statusText, statusCode: status })
        // $nuxt只在客戶端渲染能用
  } else {
        // $nuxt在SSR時undefined
  }
  return Promise.reject(error)
})
  • 写回答

1条回答 默认 最新

  • 小白 猿 2024-01-18 10:16
    关注

    API返回了500,做axios错误拦截试试

    评论

报告相同问题?

悬赏问题

  • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?