import axios from
'axios'
import { Loading, Message } from
'element-ui'
axios.defaults.timeout = 5000
var
loadinginstace
axios.interceptors.request.use(config => {
loadinginstace = Loading.service({ fullscreen:
true
})
return
config
}, error => {
loadinginstace.close()
Message.error({
message:
'加載超時'
})
return
Promise.reject(error)
})
axios.interceptors.response.use(data => {
loadinginstace.close()
return
data
}, error => {
loadinginstace.close()
Message.error({
message:
'加載失敗'
})
return
Promise.reject(error)
})
export
default
axios
設置登錄攔截
import Vue from
'vue'
import Router from
'vue-router'
Vue.use(Router)
const router =
new
Router({
routes: [
{
path:
'/'
,
component: (resolve) => {
require([
'../components/Home'
], resolve)
}
}, {
path:
'/record'
,
name:
'record'
,
component: (resolve) => {
require([
'../components/Record'
], resolve)
}
}, {
path:
'/Register'
,
name:
'Register'
,
component: (resolve) => {
require([
'../components/Register'
], resolve)
}
}, {
path:
'/Luck'
,
name:
'Luck'
,
meta: {
requireAuth:
true
},
component: (resolve) => {
require([
'../components/luck28/Luck'
], resolve)
}
}
]
})
router.beforeEach((to, from, next) => {
if
(to.matched.some(res => res.meta.requireAuth)) {
if
(localStorage.getItem(
'username'
)) {
next()
}
else
{
next({
path:
'/Register'
,
query: {redirect: to.fullPath}
})
}
}
else
{
next()
}
})
export
default
router