【若依项目-RuoYi】掌握若依前端的基本流程

  • 搞毕设项目,使用前后端分离技术,后端springBoot,前端vue3+element plus。
  • 自己已经写好前端与后端代码,但想换一个前端界面所以使用到了若依,前前后后遇到许多坑,记录一下,方便之后能够快速回忆。【本文章主要讲解前端部分(vue3),请耐心跟着文章的流程走,后端使用的是自己的工程,需要看后端的小伙伴可以看看其他的文章】

                                                                                                                        记于2024-7-30

若依官网:RuoYi 若依官方网站 |后台管理系统|权限管理系统|快速开发框架|企业管理系统|开源框架|微服务框架|前后端分离框架|开源后台系统|RuoYi|RuoYi-Vue|RuoYi-Cloud|RuoYi框架|RuoYi开源|RuoYi视频|若依视频|RuoYi开发文档|若依开发文档|Java开源框架|Java|SpringBoot|SrpingBoot2.0|SrpingCloud|Alibaba|MyBatis|Shiro|OAuth2.0|Thymeleaf|BootStrap|Vue|Element-UI||www.ruoyi.vip


1、环境准备

1.1、前端下载

        因为我原前端使用的技术栈是vue3+element plus,所以选择官网内项目扩展中的RuoYi-Vue3:  https://github.com/yangzongzhuan/RuoYi-Vue3

需要注意官网内分离版的技术栈:

  • Vue 2.6.x
  • Axios 0.21.x
  • Element 2.15.x

        当时没注意直接使用官网分离版中的项目,后面把原前端的代码拷贝过去出了问题,原因是版本过低需要升级,而且就算升级后代码语法的差异也需要大作更改,所以根据需求选择。

1.2、后端下载

后端可以直接下载官网中的项目:RuoYi-Vue: 🎉 基于SpringBoot,Spring Security,JWT,Vue & Element 的前后端分离权限管理系统,同时提供了 Vue3 的版本

 里面包含了所需的后端工程以及(Vue 2.6.x)前端工程 ruoyi-ui。

需要多看官网文档,包含了前端与后端工程的目录结构说明,方便快速掌握。


2、从登录到首页的前端流程

  1. 将前端与后端工程分别运行起来。
  2. 了解前端工程目录基本作用
  3. 主要操作都在src文件夹中。

(1)修改 vite.config.js 文件中proxy的后端ip以及端口(使用反向代理实现跨域请求)

(2)在 src -> api 中定义好自己的请求js:

(3)登录页面:src -> views -> login.vue:

        import引入user文件中的userUserStore对象,该文件主要写执行请求方法的action。

(4)执行login.vue中的登录方法后调用 store -> modules -> user 中的后端登录接口,成功后使用cookie保存token

(5)执行login.vue的登录方法成功后进行路由跳转router.push(....),但会被 src -> permission.js 文件内的路由前置守卫拦截路由跳转,需要执行两个请求:

  • userUserStore对象中的获取用户信息接口(src/store/modules/user)
  • userPermissionStore对象中的获取路由菜单接口(src/store/modules/permission)

(5.1)获取用户信息 getInfo()

【需要注意获取用户信息后需要填写一些信息,因为每次加载完路由会 next({...to,replace: true}) 更新页面,发现有token,但是没用户信息,就会重复触发调用接口请求,出现循环执行两接口造成浏览器白屏问题】

可以根据需要写一些静态数据【具体的可以查看若依后端接口查看作用】

this.roles = ['admin']        // 菜单权限
this.permissions = ['*:*:*']        // 按钮权限

this.id = data.id        // 用户id
this.name = data.name        // 用户姓名
this.avatar = avatar        // 用户头像

(5.2)获取路由菜单表信息 generateRoutes()

该action方法会调用后端接口(src -> api -> menu.js)获取菜单表

路由表结构(可以参考,但具体以若依后端传递的菜单结构为准,可以在前端这文件使用控制台输出查看)【存在其他奇奇怪怪bug,需要根据自己项目去调试,最好是一次过】:

{"code": 200,"message": "操作成功","data": [{"name": "system","path": "/system",  // 需要注意父菜单path需要加/,否则会找不到组件报404"hidden": false,    // 是否隐藏路由,当设置 true 的时候该路由不会再侧边栏出现"redirect": "noRedirect", // 重定向地址,当设置 noRedirect 的时候该路由在面包屑导航中不可被点击"component": "Layout","alwaysShow": true, // 当你一个路由下面的 children 声明的路由大于1个时,自动会变成嵌套的模式--如组件页面"meta": {"title": "系统管理","icon": "system","noCache": false, // 设置为true,则不会被 <keep-alive>缓存"link": null     // 内链地址(http(s)://开头)},"children": [{"name": "Role","path": "Role",    // 子菜单path不需要加/"hidden": false,"component": "system/sysUser","meta": {"title": "用户管理","icon": "user","noCache": false,"link": null}},{"name": "User","path": "User","hidden": false,"component": "system/sysRole","meta": {"title": "角色管理","icon": "peoples","noCache": false,"link": null}}]},{"name": "product","path": "/product","hidden": false,"redirect": "noRedirect","component": "Layout","alwaysShow": true,"meta": {"title": "商品管理","icon": "shopping","noCache": false,"link": null},"children": [{"name": "category","path": "category","hidden": false,"component": "product/category","meta": {"title": "分类管理","icon": "404","noCache": false,"link": null}}]}]
}

3、修改若依框架图标与文字

若依RuoYi框架log图标与文字怎么改?_若依的图标文字-CSDN博客

3.1、修改菜单栏上方图标

图片路径: /src/assets/logo/logo.png

3.2、修改菜单栏上方文字

文件路径:/src/layout/components/Sidebar/Logo.vue

3.3、修改窗口标签图标

图标路径:/public/favicon.ico         # 推荐尺寸64*64

3.4、修改窗口标签文字

文件目录:
/.env.development
/.env.production
/.env.staging
推荐全部修改,因为根据环境不同

3.5、免费图片转换网站 ​

在线转换图像文件


4、出现的bug

4.1、RuoYi点击菜单出现空白页面,无报错

解决:RuoYi点击菜单出现空白页面,无报错_页面在菜单点击空白-CSDN博客

若依(vue3版本),进入首页后选择左侧菜单栏会出现切换菜单或者tab 页面空白的情况,

刷新页面后又恢复正常。

        vue3版本的若依框架存在一些bug,在src\layout\components\AppMain.vue中transition加跳转动画,keep-alive用作缓存,因为同时使用了transition和keep-alive,并在组件内又使用了transition导致的。

解决方案:

1、在keep-alive外包裹上div(推荐)

<router-view v-slot="{ Component, route }"><transition:duration="{ enter: 800, leave: 100 }"mode="out-in"name="el-fade-in-linear"><div :key="route.path"><keep-alive :include="cachedViews"><component :is="Component" :key="route.path" /></keep-alive></div></transition></router-view>

2、直接注释掉transition,但这样就没有菜单切换动画了

<router-view v-else v-slot="{ Component, route }"><keep-alive :include="cachedViews"><component :is="Component" :key="route.path" /></keep-alive>
</router-view>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/393959.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

尚硅谷谷粒商城项目笔记——八、安装node.js【电脑CPU:AMD】

八、安装node.js 注&#xff1a; [!NOTE] 查看本机系统 官网选择node.js版本 1傻瓜式安装&#xff0c;注意选择路径 图一 图二 至此&#xff0c;nodejs安装完成&#xff01; 2环境配置 找到安装nodejs的路径新增 node_global 和node_cache文件夹 创建完两个空文件夹&#x…

如何快速入门 PyTorch ?

PyTorch是一个机器学习框架&#xff0c;主要依靠深度神经网络&#xff0c;目前已迅速成为机器学习领域中最可靠的框架之一。 PyTorch 的大部分基础代码源于 Ronan Collobert 等人 在 2007 年发起的 Torch7 项目&#xff0c;该项目源于 Yann LeCun 和 Leon Bottou 首创的编程语…

0207、创建场景状态的三个子类

VS使用的是3.5框架&#xff0c;会自带Linq这一行&#xff0c;Unity不支持&#xff0c;需要删除 一、创建三个场景 二、创建三个子类

本科阶段最后一次竞赛Vlog——2024年智能车大赛智慧医疗组准备全过程——5Webscoket节点的使用

本科阶段最后一次竞赛Vlog——2024年智能车大赛智慧医疗组准备全过程——5Webscoket节点的使用 ​ 有了前面几篇文章的铺垫&#xff0c;现在已经可以实现我到手测试那一步的 1.解读usb_websocket_display.launch.py ​ 首先进入这个目录/root/dev_ws/src/origincar/originca…

Java语言程序设计——篇十二

&#x1f33f;&#x1f33f;&#x1f33f;跟随博主脚步&#xff0c;从这里开始→博主主页&#x1f33f;&#x1f33f;&#x1f33f; 欢迎大家&#xff1a;这里是我的学习笔记、总结知识的地方&#xff0c;喜欢的话请三连&#xff0c;有问题可以私信&#x1f333;&#x1f333;&…

ChatGPT能代替网络作家吗?

最强AI视频生成&#xff1a;小说文案智能分镜智能识别角色和场景批量Ai绘图自动配音添加音乐一键合成视频百万播放量https://aitools.jurilu.com/ 当然可以&#xff01;只要你玩写作AI玩得6&#xff0c;甚至可以达到某些大神的水平&#xff01; 看看大神、小白、AI输出内容的区…

【枚举 图论】2242. 节点序列的最大得分

本文涉及知识点 枚举 图论知识汇总 LeetCode 2242. 节点序列的最大得分 给你一个 n 个节点的 无向图 &#xff0c;节点编号为 0 到 n - 1 。 给你一个下标从 0 开始的整数数组 scores &#xff0c;其中 scores[i] 是第 i 个节点的分数。同时给你一个二维整数数组 edges &…

logging日志实操入门

一、代码 import logging from logging.handlers import RotatingFileHandler # 配置日志 log_file_path ./logs/test.log file_handler RotatingFileHandler(log_file_path, maxBytes10, backupCount5)# 设置格式化器&#xff0c;以使日志更易读 formatter logging.Format…

Webstorm的下载与安装

Webstorm的下载 1 在浏览器的地址栏输入https://www.jetbrains.com/webstorm/&#xff0c;进入主页面 2 点击右上角的Download按钮&#xff0c;进入下载页面&#xff0c;如图所示 Webstorm的安装 按步骤逐步安装即可

SwiftUI 如何定制 Picker 视图当前选中行的背景颜色?

功能需求 有时我们希望可以定制 SwiftUI 中 Picker 视图当前选中行的背景色,这可以做到吗? 在上面的演示图中,我们随心所欲地变换着 SwiftUI 中 Picker 视图当前选中行的背景色。这是怎么做到的呢? 在本篇博文中,您将学到以下内容 功能需求1. 钩深极奥:修改 SwiftUI 原…

嵌入式学习之路 13(C语言基础学习——预处理命令)

编程流程 在进行程序开发时&#xff0c;通常遵循编辑源代码、编译、运行和调试这几个主要步骤。 编辑源代码&#xff1a;使用文本编辑器创建或修改程序的源代码&#xff0c;这是整个编程过程的起点。编译&#xff1a;将源代码转换为可执行文件的关键步骤。 预处理&#xff1a…

C#重要知识归纳总结

C#教程 C# 结构体&#xff08;Struct&#xff09; | 菜鸟教程C# 结构体&#xff08;Struct&#xff09; 在 C# 中&#xff0c;结构体&#xff08;struct&#xff09;是一种值类型&#xff08;value type&#xff09;&#xff0c;用于组织和存储相关数据。 在 C# 中&#xff0c…

微服务-实现nacos的集群和Gateway网关的实现、认证校验、解决跨域

1. nacos的集群模式 1.1 分析 nacos在企业中的使用100%都是集群模式。需要掌握nacos集群的搭建 nacos的数据存放在derby本地磁盘中&#xff0c;nacos集群模式会导致数据库数据不一致&#xff0c;使用加一层思想&#xff0c;修改nacos的数据库&#xff0c;使用mysql数据库&…

浅析中国蚁剑的木马加密流量

简介 在蓝帽杯 2022 初赛中&#xff0c;domainhacker 的流量分析题目聚焦于中国蚁剑这款 webshell 管理工具的流量特征。通过对比赛提供的数据包进行解析&#xff0c;本文将深入分析蚁剑在连接木马时产生的加密流量。 公司安全部门&#xff0c;在流量设备中发现了疑似黑客入侵的…

idea使用free流程,2024idea免费使用

1.先到官网下载&#xff0c;这里选择win系统的&#xff0c;点击下图的.exe https://www.jetbrains.com/idea/download/?sectionwindows 2.下载好后基本上就是一直点击“下一步”到直到安装好&#xff0c;安装好后先打开软件后关闭退出 3.下载配配套资料 链接: https://pan.ba…

MySQL内存模型与相关技术

MySQL实例的大概结构如下 如上图所示&#xff0c;InnoDB的存储引擎右多个内存块 维护所有进程/线程需要访问多个内部数据结构缓存磁盘上的数据&#xff0c;方便快速读取&#xff0c;且修改的数据缓存在此&#xff0c;满了后统一写入磁盘重做日志&#xff08;redo log&#xf…

5.3 需求分析

需求分析 软件需求定义分类练习题 需求工程需求获取练习题 需求分析状态转化图数据流图DFD顶层数据流图0层数据流图1层数据流图 练习题 需求规约需求定义方法 需求验证需求管理版本控制需求跟踪变更控制练习题 考试大概3分 软件需求 定义 软件需求&#xff1a;是指用户对目标…

【QT常用技术讲解】tableWidget右键菜单及多进程编程

前言 本文在QT项目的开发框架的基础上&#xff08;源代码&#xff09;增加tableWidget的右键菜单功能&#xff0c;并使用进程实现ping计算机的功能来讲解&#xff0c;本文不对进程间通信进行讲解。 概述 一个项目在开发过程中&#xff0c;通常面临着引入“第三方应用”&#x…

春秋云境 | 文件上传 | CVE-2022-30887

目录 靶标介绍 开启靶场 上传一句话木马 蚁剑连接 找到 flag 靶标介绍 多语言药房管理系统 (MPMS) 是用 PHP 和 MySQL 开发的, 该软件的主要目的是在药房和客户之间提供一套接口&#xff0c;客户是该软件的主要用户。该软件有助于为药房业务创建一个综合数据库&#xff0…

【代码随想录训练营第42期 Day22打卡 回溯Part1 - LeetCode 77. 组合 216.组合总和III 17.电话号码的字母组合

目录 一、做题心得 二、回溯基础知识 1.定义 2.适用问题 3.一个思想 4.代码实现 三、题目与题解 题目一&#xff1a;77. 组合 题目链接 题解&#xff1a;回溯 题目二&#xff1a;216.组合总和III 题目链接 题解&#xff1a;回溯 题目三&#xff1a;17.电话号码的字…