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>
相关推荐
摇滚侠5 分钟前
Vue 项目实战《尚医通》,实名认证模块静态的搭建,笔记53
vue.js·笔记
程序员鱼皮14 分钟前
又被 Cursor 烧了 1 万块,我麻了。。。
前端·后端·ai·程序员·大模型·编程
孟祥_成都26 分钟前
nextjs 16 基础完全指南!(一) - 初步安装
前端·next.js
程序员爱钓鱼27 分钟前
使用简单 JSON + 自定义 t 函数实现轻量多语言国际化(无需 next-intl)
前端·javascript·trae
一 乐39 分钟前
助农平台|基于SprinBoot+vue的助农服务系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·ecmascript·springboot
vivo互联网技术41 分钟前
浅谈 AI 搜索前端打字机效果的实现方案演进
前端·vue·dom
●VON43 分钟前
Electron 小游戏实战:太空打砖块(Space Breakout)
前端·javascript·electron
新晨43743 分钟前
Vue 3 定时器清理的最佳实践
javascript·vue.js
重铸码农荣光44 分钟前
深入理解 JavaScript 原型机制:从“如何拿到小米 SU7”说起
前端·javascript
乐观的用户1 小时前
搞懂虚拟列表实现原理与步骤
前端·vue.js