路由--导航守卫 (路由过滤器)

简介: 路由--导航守卫 (路由过滤器)

路由--导航守卫 (路由过滤器)

引:正如其名,vue-router 提供的导航守卫主要用来通过跳转或取消的方式守卫导航。有多种机会植入路由导航过程中:全局的, 单个路由独享的, 或者组件级的。


记住参数或查询的改变并不会触发进入/离开的导航守卫。你可以通过观察 $route 对象来应对这些变化,或使用 beforeRouteUpdate 的组件内守卫。


image.png


导航守卫分为三种:全局守卫、独享守卫、组件守卫。


1、全局守卫

在router的index里面通过 router实例对象配置

const router = new VueRouter({
    routes: [{
        path: '/home',
        component: HomeLayout,
        children: [
......
})
/**
 * 全局路由,前置守卫,在路由切换前调用
 *  to:即将要进入的目标 路由对象
 *  from :当前导航正要离开的路由
 *  next:进行管道中的下一个钩子 @TODO 必须调用  如果不调用 就不会发生跳转
 *
 * 可以加一些限制条件  例如:是否已经登录....
 *
 */
router.beforeEach((to, from, next) => {
    console.log(to, from, next,localStorage.getItem("isLogin"))
    if (localStorage.getItem("login")=='ok') {
        //要主动调用
        next()
    } else {
        alert("请先去登录")
    }
});
/**
 * 全局路由,后置守卫,在路由切换后调用
 *  to:即将要进入的目标 路由对象
 *  from :当前导航正要离开的路由
 *
 *  例如:可以做修改 网页 title 名称-->document.title=""
 *
 */
router.afterEach((to, from) => {
    console.log(to, from,)
});

2、独享守卫

在router的index里面通过 router实例里面的路由节点里面配置

const router = new VueRouter({
    routes: [{
        path: '/home',
        component: HomeLayout,
        children: [
            {
                path: 'news',
                component: NewsLayout,
                //独享守卫 
                beforeEnter: (to, from, next) => {
                    console.log(to, from, next)
                    next()
                }
                }
            }, {
         ......
])

3、组件守卫

在组件里面配置

export default {
        name: "Demo", 
//@TODO 进来这个组件之前调用
        beforeRouteEnter(to, from, next) {
            // 在渲染该组件的对应路由被 confirm 前调用
            // 不!能!获取组件实例 `this`
            // 因为当守卫执行前,组件实例还没被创建
            console.log(to, from, next)
            next()
        },
        //@TODO 在这个组件里面 打开子组件时调用
        beforeRouteUpdate(to, from, next) {
            // 在当前路由改变,但是该组件被复用时调用
            // 举例来说,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候,
            // 由于会渲染同样的 Foo 组件,因此组件实例会被复用。而这个钩子就会在这个情况下被调用。
            console.log(to, from, next)
            next()
        },
        //@TODO 离开这个组件之前调用
        beforeRouteLeave(to, from, next) {
            // 导航离开该组件的对应路由时调用
            // 可以访问组件实例 `this`
            console.log(to, from, next)
            next()
        }
}

路由元信息(meta)

配置:

const router = new VueRouter({
    routes: [{
        path: '/home',
        component: HomeLayout,
        meta: {
            title: "主页"
        },
        children: [
              ......
   })

使用:

/**
 * 全局路由,后置守卫,在路由切换后调用
 *  to:即将要进入的目标 路由对象
 *  from :当前导航正要离开的路由
 *
 *  例如:可以做修改 网页 title 名称-->document.title=""
 *
 */
router.afterEach((to, from) => {
    console.log(to, from,)
   document.title = to.meta.title
});

Vue 导航守卫官网地址

https://v3.router.vuejs.org/zh/guide/advanced/navigation-guards.html#%E5%85%A8%E5%B1%80%E5%8


目录
相关文章
|
SQL 关系型数据库 MySQL
深入浅出MySQL(八) 超详细的MySQL主从配置
深入浅出MySQL(八) 超详细的MySQL主从配置
1610 0
|
7月前
|
人工智能 安全 搜索推荐
SecMulti-RAG:兼顾数据安全与智能检索的多源RAG框架,为企业构建不泄密的智能搜索引擎
本文深入解析SecMulti-RAG框架,该框架通过整合企业内部知识库、预构建专家知识及受控外部大语言模型,结合保密性过滤机制,解决企业在部署AI助手时面临的信息准确性、数据安全性和成本控制问题。它采用多层策略,利用三种知识来源(动态更新的企业知识、专家预写知识和按需外部知识),并通过微调的开源LLM生成最终响应,确保安全性与性能。实验表明,SecMulti-RAG在汽车行业技术报告生成任务中显著优于传统RAG系统,展现了其在企业环境中的实用性和优势。
277 5
SecMulti-RAG:兼顾数据安全与智能检索的多源RAG框架,为企业构建不泄密的智能搜索引擎
|
存储 自然语言处理 关系型数据库
MySQL 自定义变量并声明字符编码
MySQL 自定义变量并声明字符编码
437 1
|
SQL 数据挖掘 测试技术
南大通用GBase8s数据库:LISTAGG函数的解析
南大通用GBase8s数据库:LISTAGG函数的解析
|
JSON 调度 数据库
Android面试之5个Kotlin深度面试题:协程、密封类和高阶函数
本文首发于公众号“AntDream”,欢迎微信搜索“AntDream”或扫描文章底部二维码关注,和我一起每天进步一点点。文章详细解析了Kotlin中的协程、扩展函数、高阶函数、密封类及`inline`和`reified`关键字在Android开发中的应用,帮助读者更好地理解和使用这些特性。
343 1
|
JavaScript 前端开发 Java
如何使用这个正则表达式来验证一个字符串是否符合特定的格式要求?
如何使用这个正则表达式来验证一个字符串是否符合特定的格式要求?
|
9月前
|
人工智能 JavaScript 程序员
基于 AI 程序员完成新功能开发
基于AI的程序员工具能自动分析并修复编译、调试错误。例如在Vite项目中遇到“ReferenceError: loadEnv is not defined”时,AI可快速定位问题为loadEnv未正确定义或导入,并提供具体解决方案,如检查导入语句、函数定义、配置文件及依赖项版本,帮助开发者高效解决问题。此外,AI还支持一键替换和导入功能,减少代码编写量,提升开发效率。[了解更多](https://blog.csdn.net/qq_41589580/article/details/145779783)
|
机器学习/深度学习 算法 Python
BP神经网络算法讲解及实战应用(超详细 附源码)
BP神经网络算法讲解及实战应用(超详细 附源码)
3101 0
|
监控 API 开发者
后端开发中的微服务架构实践与优化
【10月更文挑战第17天】 本文深入探讨了微服务架构在后端开发中的应用及其优化策略。通过分析微服务的核心理念、设计原则及实际案例,揭示了如何构建高效、可扩展的微服务系统。文章强调了微服务架构对于提升系统灵活性、降低耦合度的重要性,并提供了实用的优化建议,帮助开发者更好地应对复杂业务场景下的挑战。
226 7
|
存储 C语言
【CSAPP随笔】CH3:Bits, Bytes, and Integers
【CSAPP随笔】CH3:Bits, Bytes, and Integers
183 0