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>
相关推荐
CSR-kkk几秒前
前端工程化速通——①ES6
前端·es6·速通
yt948325 分钟前
C#实现CAN通讯接口
java·linux·前端
前端小巷子6 分钟前
Cookie与Session:Web开发中的身份验证与数据存储
前端·javascript·面试
小磊哥er17 分钟前
【前端工程化】前端开发中如何做一套规范的项目模版
前端
Wetoria28 分钟前
管理 git 分支时,用 merge 还是 rebase?
前端·git
前端开发与ui设计的老司机38 分钟前
UI前端与数字孪生融合新领域:智慧环保的污染源监测与治理
前端·ui
一只小风华~1 小时前
Web前端开发: :has功能性伪类选择器
前端·html·html5·web
Mr_Mao5 小时前
Naive Ultra:中后台 Naive UI 增强组件库
前端
前端小趴菜056 小时前
React-React.memo-props比较机制
前端·javascript·react.js
摸鱼仙人~7 小时前
styled-components:现代React样式解决方案
前端·react.js·前端框架