登录验证
依赖项
“vue”: “^2.6.11”
“vue-router”: “^3.2.0”
router.js
import Vue from 'vue'
import VueRouter from 'vue-router'
import Login from '../pages/Login.vue'
Vue.use(VueRouter)
const routes = [{
path: '/',
name: 'login',
component: Login
},
{
path: '/homeIndex',
name: 'homeIndex',
meta: {
requireAuth: true
},
component: () => import('../pages/Index.vue'),
redirect: '/home',
children: [{
path: '/home',
name: 'home',
meta: {
requireAuth: true
},
component: () => import('../pages/Home.vue')
}
]
}
]
const router = new VueRouter({
routes
})
export default router
main.js
import Vue from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'
router.beforeEach((to, from, next) => {
if (to.meta.requireAuth) {
if (sessionStorage.getItem("author")) {
next()
} else {
next('/')
return //不会调用主页接口
}
} else {
//没有开启路由验证
next() //放行
}
})
new Vue({
router,
store,
render: h => h(App)
}).$mount('#app')
同路由跳转报错
依赖项
“vue”: “^2.6.11”
“vue-router”: “^3.2.0”
router.js
import Vue from 'vue'
import VueRouter from 'vue-router'
Vue.use(VueRouter)
const originalPush = VueRouter.prototype.push
VueRouter.prototype.push = function push(location, onResolve, onReject) {
if (onResolve || onReject) return originalPush.call(this, location, onResolve, onReject)
return originalPush.call(this, location).catch(err => err)
}