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>
相关推荐
万少10 分钟前
HarmonyOS 开发必会 5 种 Builder 详解
前端·harmonyos
橙序员小站2 小时前
Agent Skill 是什么?一文讲透 Agent Skill 的设计与实现
前端·后端
炫饭第一名5 小时前
速通Canvas指北🦮——基础入门篇
前端·javascript·程序员
王晓枫5 小时前
flutter接入三方库运行报错:Error running pod install
前端·flutter
符方昊5 小时前
React 19 对比 React 16 新特性解析
前端·react.js
ssshooter5 小时前
又被 Safari 差异坑了:textContent 拿到的值居然没换行?
前端
曲折5 小时前
Cesium-气象要素PNG色斑图叠加
前端·cesium
Forever7_6 小时前
Electron 淘汰!新的桌面端框架 更强大、更轻量化
前端·vue.js
不会敲代码16 小时前
前端组件化样式隔离实战:React CSS Modules、styled-components 与 Vue scoped 对比
css·vue.js·react.js
Angelial6 小时前
Vue3 嵌套路由 KeepAlive:动态缓存与反向配置方案
前端·vue.js