$router' of undefined 是什么原因?

有一个需求:
后端返回状态码-999表示token过期,前端要跳到登录页。

我的代码:
http.js

    import axios from 'axios'
    import Vue from "vue"
    import VueRouter from 'vue-router'
    import { Message } from "element-ui";
    import common from './global.js'
    Vue.use(VueRouter)
    
axios.interceptors.response.use(
    response => {
        //token过期处理
        if(response.data.code == -999){
            Message({
                message: '身份已过期,请重新登录!',
                type: 'warning'
            });
            this.$router.push('/login');
            this.common.delCookie('token');
            this.common.delLocal();
        }
        return response;
    },
    error => {
        Message({
            message: '服务器响应失败',
            type: 'warning'
        });
        return Promise.reject(error.response.data)
});

提示了一句“Cannot read property '$router' of undefined”

阅读 5.2k
5 个回答
import router from '@/router';
...
router.push('/login');

this里面没$router 这个属性

你的this指向谁的呢

新手上路,请多包涵

用axios的方法会改变this指向,用axios方法前,缓存this指针

js文件中this不是指向 new Vue() 的呀,.vue 文件中才指向 Vue 实例

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题