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>
相关推荐
毛骗导演1 分钟前
@tencent-weixin/openclaw-weixin 插件深度解析(四):API 协议与数据流设计
前端·架构
毛骗导演5 分钟前
@tencent-weixin/openclaw-weixin 插件深度解析(二):消息处理系统架构
前端·架构
IT_陈寒23 分钟前
深入理解JavaScript:核心原理与最佳实践
前端·人工智能·后端
MrGud28 分钟前
Cesium中的坐标系及其转换
前端·cesium
小付学代码28 分钟前
香港地图可编辑版
前端
兆子龙40 分钟前
TypeScript高级类型编程:从入门到精通
前端·后端
SuperEugene42 分钟前
Vue3 模板语法规范实战:v-if/v-for 不混用 + 表达式精简,避坑指南|Vue 组件与模板规范篇
开发语言·前端·javascript·vue.js·前端框架
IT_陈寒1 小时前
Python开发者的效率革命:这5个技巧让你的代码提速50%!
前端·人工智能·后端
Luna-player1 小时前
Vue 3 + Vue Router 的路由配置,简单示例
前端·javascript·vue.js
用户69371750013841 小时前
不卷AI速度,我卷自己的从容——北京程序员手记
android·前端·人工智能