关于nuxt.js:nuxt-路由拦截

58次阅读

共计 821 个字符,预计需要花费 3 分钟才能阅读完成。

1,配置

1.1,plugin 下创立 userAuth 文件

export default (context) => {if(process.client){const token = sessionStorage.getItem('token');
    context.app.router.beforeEach((to, from, next) => {if( !token && to.path !== '/login'){next('/login');
      }else if(to.path !== '/login'){next();
      }else {next();
      }
    })
  }
};

留神
1)路由以后门路和跳转门路不要反复,不然会呈现 死循环,超出堆栈问题。
Maximum call stack size exceeded
2)莫名其妙呈现的如下报错,然而清理缓存之后就隐没了。
[SSE] Connecting to /_loading/sse...
3)process.client 是判断以后是处于服务端,还是客户端。
因为,sessionStorage 是 window 对象,在服务端获取不到。

2,调用

nuxt.config.js 中调用

plugins: ['@/plugins/userAuth'],

另外:应用中间件进行路由拦挡
应用中间件会有一个问题,间接如输出指标地址,例如:https://192.1.1.1/home
会胜利进入,只有跳转到别的地址的时候,才会拦挡,跳转登录页。
所以,并不举荐应用

export default function ({route, redirect}) {if (process.client) {const token = sessionStorage.getItem('token');
    if (!token && route.path !== '/login') {redirect('/login');
    }
  }
}

参考:
nuxt 中的 process.static/process.server/process.client

正文完
 0