码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 前端Vue-vue-element-admin-router.addRoutes


    vue-element-admin的权限验证

    • router.addRoutes
      • 非常普通的路由
      • 动态添加pageA
    • 路由的权限验证

    https://panjiachen.github.io/vue-element-admin-site/zh/

    在这里插入图片描述
    在这里插入图片描述
    权限验证源码时碰到了

    router.addRoutes

    router.addRoutes
    函数签名:
    
    router.addRoutes(routes: Array<RouteConfig>)
    动态添加更多的路由规则。参数必须是一个符合 routes 选项要求的数组。 
    
    • 1
    • 2
    • 3
    • 4
    • 5

    更多动态规则?符合routes选项的要求的数组又长什么样?

    非常普通的路由

     const routes = [
      {
        path: '/',
        name: 'Home',
        component: Home
      },
    {
      path: '/pageA',
      name: 'pageA',
      component: pageA,
    }
    ]
    const router = new VueRouter({
      routes
    });
    export default router
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    使用router.addRoutes改造上面的配置,实现

    动态添加pageA

     const router = new VueRouter([
      {
        path: "/",
        name: "Home",
        component: Home
      }
    ]);
    let route=[
    {
      path: '/pageA',
      name: 'pageA',
      component: pageA,
    }]
    router.addRoutes(route);
    export default router
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    把原来的routes配置照搬到一个新的数组中,
    就可以作为addRoutes的参数使用,
    经验证,通过addRoutes动态配置的方式和普通配置无差异。

    你可能会问,这有什么用?那么接下来,我们来谈谈它的应用:

    路由的权限验证

    网页有[普通用户,管理员…]等多种角色类型,不同的角色能看到的页面应该是不同的,
    比如普通用户不应该看到管理员的控制台,那么这个时候,动态路由就非常有用了
    可以这么做

     let pageA,pageB,pageC;
    let route=[
    {
      path: '/pageA',
      name: 'pageA',
      component: pageA,
    },
    {
      path: '/pageB',
      name: 'pageB',
      component: pageB,
    },
    {
      path: '/pageC',
      name: 'pageC',
      component: pageC,
    }
    ]
    let commonUser=['pageA','pageB'];
    let commonUserRoute=route.filter(function(page){
        return commonUser.includes(page.name)
    })
    console.log(commonUserRoute);
    router.addRoutes(commonUserRoute);
    //结果
    // (2) [{…}, {…}]
    // 0: {path: "/pageA", name: "pageA", component: pageA}
    // 1: {path: "/pageB", name: "pageB", component: pageB}
    // length: 2
    // __proto__: Array(0)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
  • 相关阅读:
    Android 中的权限
    asp.net core之依赖注入
    HL7入门收集
    容器环境 springcloud gateway grafana prometheus采集集成与问题
    C++ //练习 9.19 重写上题的程序,用list替代deque。列出程序要做出哪些改变。
    推荐系统笔记(十一):使用coo_matrix函数遇到的坑
    二十一、学习Lua 面向对象
    Go/Golang语言学习实践[回顾]教程13--详解Go语言的词法解析单元
    [附源码]Python计算机毕业设计Django体育馆场地预约管理系统
    最炫表白网站html5源码_七夕程序员的十款表白源码_html+css+js
  • 原文地址:https://blog.csdn.net/qq_33608000/article/details/126216269
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号