Vue-根据角色生成动态路由及菜单-1-vue脚手架创建项目

202 阅读2分钟

根据登录用户的角色,生成路由后addRoute、生成菜单栏基本思路:

  1. 用户在登录页输入 用户名+密码 请求后端 login接口 拿到 token 后保存到cookie或sessionStorage中;

  2. 接着携带拿到的token请求后端 userInfo 接口,获得用户基本信息及角色role;

  3. 前端维护路由表,除了不需要权限限定的页面外其余每个路由添加meta数据,格式如 meta:{ role:['admin'] } ,表示该路由页面可以被哪些角色访问;

  4. 用userInfo接口拿到的role数据,过滤出路由表中,当前用户能访问的路由并保存到Vuex中,使用 Vue-Router的 addRoute API循环添加路由;

  5. 菜单栏使用了 ElementUI 的 NavMenu 导航菜单组件,拿到Vuex保存的路由数据循环即可,因为菜单可能有多个层级,使用了组件递归。

本地环境:

    Windows10系统、Node 16.8、Vue CLI 4.5.13

基本流程:

    1. 使用 Vue Cli 脚手架创建项目、安装依赖

        打开终端输入  vue create vue-admin-simple  回车,使用方向键选择 "Manually select features" 自定义选择项目需要使用的依赖;

使用 vue cli 脚手架创建项目

        选中 Manually select features 后回车,(方向键上下选择,按空格键选中和取消选中),选中“Router”和“Vuex”后回车(测试项目中使用了Vuex来保存路由和用户信息);

自定义选择项目依赖项

        回车后让选择vue版本(这里先用2.x版本,后面再写3.x版本记录)、路由是否使用History模式、ESLint配置、何时用ESLint格式化、是否把babel和ESLint等的配置项保存到各自的单独配置文件中还是保存到package.json中、是否不保存为预设配置 这几步可以依次回车默认选择即可,也可以根据自己习惯及项目需要修改选择。

自定义项目依赖配置相关

        之后回车即开始安装项目依赖了。等待依赖下载完成即可进入项目运行查看。

依赖安装完成

    2. 进入项目目录启动项目、使用VSCode打开项目编辑

        终端中继续输入 cd vue-admin-simple 回车后, 运行 yarn serve 开始编译项目。编译完成在浏览器地址栏输入 localhost:8080 回车查看项目。

编译完成给出了项目地址

浏览器输入地址查看项目运行

项目默认目录结构

下篇文章继续记录生成测试页面和路由,实现静态登录及基本页面布局layout。