一直想作一个基于VUE的项目,可是由于项目每每要涉及到后端的知识(不会后端真的苦),因此就没有一直真正的动手去作一个项目。
直到发现GitHub上有网易云音乐的api NeteaseCloudMusicApi,才开始动手去作。前端
仅仅完成了首页,登入,歌单,歌曲列表页。vue
https://github.com/qp97vi/music
项目成功运行还要把后端api在本地运行webpack
vue2+vuex+vue-router+axios+mint-ui+webpackios
前端路由拦截解决方案 原文 感谢!!!
1.前端路由拦截
想作一个登陆拦截,验证没有登陆以前,就跳转到登陆页面
解决方法是:经过http response 拦截器判断token(本地的cookie)判断
建立一个http.jsgit
import axios from 'axios' import store from './store/store' import * as types from './store/types' import router from './router/index' // axios 配置 axios.defaults.timeout = 5000 axios.defaults.baseURL = 'https://api.github.com' // http request 拦截器 axios.interceptors.request.use( config => { if (store.state.xsrfCookieName) { config.headers.Authorization = `xsrfCookieName ${store.state.xsrfCookieName}` } return config }, err => { return Promise.reject(err) }, ) // http response 拦截器 axios.interceptors.response.use( response => { return response }, error => { if (error.response) { switch (error.response.status) { case 401: // 401 清除token信息并跳转到登陆页面 store.commit(types.LOGOUT) // 只有在当前路由不是登陆页面才跳转 router.currentRoute.path !== 'login' && router.replace({ path: 'login', query: { redirect: router.currentRoute.path }, }) } } // console.log(JSON.stringify(error));//console : Error: Request failed with status code 402 return Promise.reject(error.response.data) }, ) export default axios
2.路由懒加载github
{ path:'/my', name:'my', meta:{ requireAuth:true, }, component:resolve=>{ Indicator.open('加载中...'); require.ensure(['@/views/my'], () => { resolve(require('@/views/my')) Indicator.close() }) } },
注:本文仅是用来记录学习,如涉及侵权请联系删除。web