Vue 前置 后置 路由守卫 独享 路由权限控制 自定义属性

javascript 复制代码
import Vue from 'vue'
import VueRouter from 'vue-router'
//导入路由器
Vue.use(VueRouter)

import Login from '../components/Login'
import User from '../components/User'
//导入需要路由的组件


const router = new VueRouter({
    //暴露出去使用
    routes:
        [
            {
                path: '/login',
                component: Login
            },
            {
                name: 'user',
                path: '/user',
                component: User,

            }
        ]

})


//全部组件进入路由之前
router.beforeEach((to, from, next) => {

next()
//放行 这样写表示全部放行 
//这里可以做判断,符合条件放行

})

export default router

to:到哪去

from:从哪里来

next:是否放行

用户登录规则

javascript 复制代码
if(to.path=='/user')//判断路径是否为用户中心
{

if(token....)//判断是否登录
{
next()
}

}

路由器自定义属性meta

meta属性可以自定义属性,如果网站标题,一些自定义的数据

javascript 复制代码
  {
                path: '/login',
                component: Login,
                meta: { title: '用户登录', isToken: true }
  },

//全部组件进入路由之前
router.beforeEach((to, from, next) => {

    document.title = to.meta.title
    next()

})

路由的生命周期 前置 后置

javascript 复制代码
//全部组件进入路由之前
router.beforeEach((to, from, next) => {

    next()

//在这里一般做权限校验
})


//路由进入之后
router.afterEach((to,from)=>{

//校验完毕 要做的事情 比较少用

})

独享路由守卫

也就是一个路由限制,如果个人中心,其他页面随便看,只有个人中心要校验权限,这个就可以使用独享路由守卫

javascript 复制代码
 {
 //独享前置路由守卫
                name: 'user',
                path: '/user',
                component: User,
                meta: { title: '个人中心' },
                beforeEnter: (to, from, next) => {
                
                    document.title = to.meta.title
                    next()                
                }

            }

独享路由守卫没有 后置守卫 ,但可以配置成全局的后置路由守卫

javascript 复制代码
//路由进入之后
router.afterEach((to,from)=>{

//校验完毕 要做的事情 比较少用

})

组件路由守卫

组价路由器守卫,没有前置 和 后置 这个概念

路由配置

javascript 复制代码
 {
                name: 'user',
                path: '/user',
                component: User,
                meta: { title: '个人中心' },      
 }

User组件

javascript 复制代码
<script>

    export default {
        name: 'User',

        //通过路由规则进入组件时被调用
        beforeEnter: (to, from, next) => {
            // ...
        },
        //通过路由规则离开组件时被调用  路由被切换走之前
        beforeRouteLeave(to, from, next) {
            // ...
        }
    }

</script>
相关推荐
LuckyLay几秒前
React百日学习计划-Grok3
前端·学习·react.js
澄江静如练_5 分钟前
小程序 存存上下滑动的页面
前端·javascript·vue.js
源码方舟12 分钟前
基于SpringBoot+Vue的房屋租赁管理系统源码包(完整版)开发实战
vue.js·spring boot·后端
互联网搬砖老肖20 分钟前
Web 架构之会话保持深度解析
前端·架构
m0_5139625324 分钟前
vue-ganttastic甘特图label标签横向滚动固定方法
javascript·vue.js·甘特图
菜鸟una28 分钟前
【taro3 + vue3 + webpack4】在微信小程序中的请求封装及使用
前端·vue.js·微信小程序·小程序·typescript·taro
Java&Develop34 分钟前
怎么查看当前vue项目,要求的node.js版本
vue.js
hao_041338 分钟前
elpis-core: 基于 Koa 实现 web 服务引擎架构设计解析
前端
松树戈1 小时前
openfeign与dubbo调用下载excel实践
vue.js·spring cloud·elementui·dubbo
狂野小青年1 小时前
npm 报错 gyp verb `which` failed Error: not found: python2 解决方案
前端·npm·node.js