当前位置:首页 > VUE

vue实现页面500

2026-03-10 05:20:45VUE

Vue 实现页面 500 错误处理

在 Vue 应用中处理 500 服务器错误通常涉及前端错误捕获和展示友好的错误页面。以下是几种实现方式:

使用全局错误处理

通过 Vue 的全局错误处理器 errorHandler 捕获未被处理的异常,并重定向到 500 页面。

// main.js
Vue.config.errorHandler = (err, vm, info) => {
  console.error(`Error: ${err.toString()}\nInfo: ${info}`);
  router.push('/500'); // 重定向到 500 页面
};

路由配置中捕获错误

在 Vue Router 的导航守卫中捕获 HTTP 500 错误,例如通过拦截 API 响应错误码。

vue实现页面500

// router.js
router.beforeEach((to, from, next) => {
  axios.interceptors.response.use(
    response => response,
    error => {
      if (error.response.status === 500) {
        next('/500');
      }
      return Promise.reject(error);
    }
  );
  next();
});

创建专用错误页面

设计一个 500 错误页面组件,用于展示友好的错误信息。

<!-- components/Error500.vue -->
<template>
  <div class="error-page">
    <h1>500</h1>
    <p>服务器内部错误,请稍后再试。</p>
    <button @click="$router.push('/')">返回首页</button>
  </div>
</template>

结合 HTTP 拦截器

使用 Axios 拦截器统一处理后端返回的 500 状态码,触发错误页面跳转。

vue实现页面500

// utils/http.js
axios.interceptors.response.use(
  response => response,
  error => {
    if (error.response.status === 500) {
      store.commit('setError', error.response.data.message);
      router.push('/500');
    }
    return Promise.reject(error);
  }
);

通过状态管理传递错误信息

在 Vuex 中存储错误状态,动态控制错误页面的显示内容。

// store.js
const store = new Vuex.Store({
  state: {
    error: null
  },
  mutations: {
    setError(state, error) {
      state.error = error;
    }
  }
});

服务端渲染 (SSR) 场景

对于 Nuxt.js 等 SSR 框架,可在 asyncDatafetch 方法中捕获 500 错误。

// Nuxt page component
export default {
  async asyncData({ $axios, error }) {
    try {
      const data = await $axios.$get('/api/endpoint');
      return { data };
    } catch (e) {
      error({ statusCode: 500, message: '服务器错误' });
    }
  }
};

标签: 页面vue
分享给朋友:

相关文章

vue实现https

vue实现https

Vue 中实现 HTTPS 的步骤 在 Vue 项目中实现 HTTPS 主要涉及开发环境配置和生产环境部署。以下是具体方法: 开发环境配置(Vue CLI 或 Vite) 使用 mkcert 生成…

vue分类实现

vue分类实现

Vue分类实现方法 在Vue中实现分类功能通常涉及数据分组、动态渲染和交互逻辑。以下是几种常见的实现方式: 基于计算属性的分类 通过计算属性对原始数据进行分组处理,适合静态或少量数据分类: com…

computed vue 实现

computed vue 实现

computed 在 Vue 中的基本用法 Vue 的 computed 属性用于声明依赖于其他数据的计算属性。当依赖的数据变化时,计算属性会自动重新计算并缓存结果。 export defaul…

vue实现erp

vue实现erp

Vue实现ERP系统的关键步骤 技术选型与架构设计 采用Vue 3 + TypeScript构建前端,搭配Pinia状态管理,Element Plus或Ant Design Vue作为UI框架。后端可…

实现vue table

实现vue table

Vue 表格实现方法 基础表格实现 使用 Vue 的 v-for 指令可以快速渲染表格数据。在模板中定义表格结构,通过数据绑定动态生成行和列。 <template> <tabl…

vue实现购票

vue实现购票

Vue 实现购票功能 数据结构设计 购票功能通常需要以下数据结构: 场次信息(时间、地点、价格) 座位信息(可选座位、已售座位) 用户订单信息 示例数据结构: data() { return…