【java+vue+微信小程序项目】从零开始搭建——健身房管理平台(3)路由导航卫士、主页实现

news2025/1/12 23:17:46

项目笔记为项目总结笔记,若有错误欢迎指出哟~

【项目专栏】
【java+vue+微信小程序项目】从零开始搭建——健身房管理平台(1)spring boot项目搭建、vue项目搭建、微信小程序项目搭建
【java+vue+微信小程序项目】从零开始搭建——健身房管理平台(2)后端跨域、登录模块、springboot分层架构、IDEA修改快捷键、vue代码风格
【java+vue+微信小程序项目】从零开始搭建——健身房管理平台(3)路由导航卫士、主页实现

【java+vue+微信小程序项目】从零开始搭建——健身房管理平台

  • 路由导航守卫
    • 全局前置守卫
  • 主页实现
    • 界面设计
    • 主页前端
    • 菜单路径存储在mysql数据库
    • 菜单栏前端
    • 菜单栏后端
      • 1.数据访问层
        • (1)子菜单实体SubMenu.java
        • (2)主菜单实体MainMenu.java
        • (3)MenuDao.java
        • (4)MenuMapper.xml
      • 2.业务逻辑层
        • (1)MenuService.java
        • (2)MenuServiceImpl.java
      • 3.表现层
        • (1)MenuController.java
    • 菜单栏前端添加图标
      • 1.修改Home.vue(template标签)
      • 2.修改Home.vue(script标签)
    • 主页前端子页面(默认页面)
      • 1.新建Welcome.vue
      • 2.修改Home.vue
      • 3.修改路由
    • 主页前端子页面(其他页面)
      • 1.新建组件
        • UserList.vue
        • CoachList.vue
        • CourseList.vue
        • PrivateList.vue
        • CalorieList.vue
        • NoticeList.vue
        • DietList.vue
        • ExerciseList.vue
      • 2.修改路由

路由导航守卫

路由导航守卫(Route Navigation Guards)是 Vue Router 提供的一种机制,用于在路由切换时进行一些逻辑控制和操作。

路由导航守卫分为三种:

  1. 全局前置守卫:router.beforeEach
    在路由切换开始前进行的一些验证、拦截或处理,如用户权限验证、登录状态判断、页面跳转等。
  2. 全局后置守卫:router.afterEach
    在路由切换完成后进行的一些操作,如页面统计、数据收集、动画效果等。
  3. 组件内守卫:beforeRouteEnterbeforeRouteUpdatebeforeRouteLeave
    在组件内部定义的守卫,可以通过这些守卫来进行组件级别的验证与处理。

使用路由导航守卫,可以方便地控制用户访问页面的权限,并且在路由切换时执行一些必要的操作,增强应用程序的稳定性和用户体验。

全局前置守卫

router——>index.js

const router = new VueRouter({
   
  routes,
});

// 挂载路由导航守卫
router.beforeEach((to, from, next) => {
   
  if (to.path == '/login') return next();
  // 获取user
  const userFlag = window.sessionStorage.getItem("user");
  if (!userFlag) return next('/login');
  next(); 
})
// 出现问题的时候使用
const originalPush = VueRouter.prototype.push
VueRouter.prototype.push = function push(location, onResolve, onReject) {
   
  if (onResolve || onReject) return originalPush.call(this, location, onResolve, onReject)
  return originalPush.call(this, location).catch(err => err)
}

export default router;
  1. router.beforeEach 方法用于注册一个全局前置守卫,会在路由切换前进行验证。当用户尝试访问任何路径时,都会先执行这个函数。
  2. beforeEach 函数中,判断即将访问的路径是否为 /login,如果是,则直接放行,不进行后续验证。
  3. 通过 window.sessionStorage.getItem("user") 获取当前用户信息。如果不存在用户信息,说明用户未登录,强制跳转到登录页。
  4. 如果存在用户信息,表示用户已登录,直接放行。
  5. 下面的代码是对 Vue Router 的 push 方法进行了一些处理,以解决编程式导航时可能出现的问题,例如没有捕获到错误导致的报错。
    这段代码是对 Vue Router 的 push 方法进行了一些处理,主要是为了解决在编程式导航时可能出现的问题。
  • 首先,通过 const originalPush = VueRouter.prototype.push 将原始的 push 方法保存到 originalPush 变量中,以便后续调用。

  • 然后,重新定义了 VueRouter.prototype.push 方法。此时,当我们在代码中使用 router.push() 进行页面跳转时,实际上会执行重新定义后的方法。

  • 在重新定义的方法中,首先判断了两个参数 onResolveonReject 是否存在。这两个参数通常在使用 Promise API 时才会传入,用于处理异步操作的回调。

    • 如果 onResolveonReject 存在,说明是使用了 Promise API,并且传入了相应的回调函数。则直接调用原始的 push 方法,并将参数传递过去,同时返回其返回值(Promise)。
    • 如果 onResolveonReject 都不存在,则说明没有传入回调函数,此时调用原始的 push 方法,并使用 .catch(err => err) 捕获可能的错误,以避免出现未捕获的异常错误。

    这样做的目的是为了确保在编程式导航时能够正常捕获错误。如果在路由跳转过程中发生了错误,通过这段代码的处理,程序不会抛出异常,而是将错误信息返回给调用者,避免导致程序崩溃。

主页实现

界面设计

在这里插入图片描述
实现:
在这里插入图片描述

主页前端

element-ui Layout 布局:https://element.eleme.cn/#/zh-CN/component/layout

components——>Home.vue

<template>
  <!-- 引入container布局 -->
  <el-container class="home-container">
    <!-- 头部 -->
    <el-header>
      <div>
        <img src="../assets/logo.jpg" alt class="logo_img" />
        <span>Power健身房管理平台</span>
      </div>
      <el-button type="info" @click="logout">安全退出</el-button>
    </el-header>
    <!-- 主体 -->
    <el-container>
      <!-- 侧边栏 -->
      <el-aside width="200px">
        
      </el-aside>
      <!-- 主体内容 -->
      <el-main>
        
      </el-main>
    </el-container>
  </el-container>
</template>
  
<script>
</script>
  
  
<style lang="less" scoped>
.home-container {
     
  height: 100%;
}

// 头部样式
.el-header {
     
  background-color: #373d41;
  display: flex;
  justify-content: space-between; // 左右贴边
  padding-left: 0%; // 左边界
  align-items: center; // 水平
  color: #fff;
  font-size: 20px;
  > div {
     
    //左侧div加布局
    display: flex;
    align-items: center;
    span {
     
      margin-left: 15px;
    }
  }
}
// 侧边栏样式
.el-aside {
     
  background-color: #333744;
  .el-menu {
     
    border-right: none;
  }
}
// 主体样式
.el-main {
     
  background-color: #eaedf1;
}

.logo_img {
     
  width: 55px;
  height: 55px;
  border-radius: 50%; // 加圆角
}

//按钮样式
.toggle-button {
     
  background-color: #4a5064;
  font-size: 10px;
  line-height: 24px;
  color: #fff;
  text-align: center;
  letter-spacing: 0.2em;
  cursor: pointer; // 显示鼠标指针为:小手
}
</style>

在这里插入图片描述

菜单路径存储在mysql数据库

drop table if exists mainmenu;
-- 主菜单表
create table mainmenu(
	id bigint(20) not null primary key comment '主键',
	title varchar(100) comment '菜单名称',
	path varchar(100) comment '菜单路径'
);

drop table if exists submenu;
-- 子菜单表
create table submenu(
	id bigint(20) not null primary key comment '主键',
	title varchar(100) comment '菜单名称',
	path varchar(100) comment '菜单路径',
	mid bigint(20) comment '主菜单id',
	foreign key (mid) references fitness_center.mainmenu(id)
);

在这里插入图片描述

-- 主菜单
insert into mainmenu values(100,'业务管理','/admin');
insert into mainmenu values(200,'资讯管理','/use');

-- 子菜单
insert into submenu values(101,'用户列表','/user',100);
insert into submenu values(102,'教练列表','/coach',100);
insert into submenu values(103,'课程列表','/course',100);
insert into submenu values(104,'私教预约列表','/private',100);
insert into submenu values(201,'通知公告','/notice',200);
insert into submenu values(202,'卡路里','/calorie',200);
insert into submenu values(203,'饮食记录','/diet',200);
insert into submenu values(204,

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【带头学C++】----- 九、类和对象 ---- 9.2 构造函数

目录 9.2 构造函数 9.2.1 构造函数的概述 9.2.2 构造函数定义方法&#xff08;初始化构造函数&#xff09; 9.2.3 提供构造函数的影响 9.2 构造函数 以下是一些C引入构造函数的原因&#xff1a; 初始化对象&#xff1a;构造函数允许在创建对象时立即初始化该对象的成员变量…

数据挖掘实战-基于word2vec的短文本情感分析

&#x1f935;‍♂️ 个人主页&#xff1a;艾派森的个人主页 ✍&#x1f3fb;作者简介&#xff1a;Python学习者 &#x1f40b; 希望大家多多支持&#xff0c;我们一起进步&#xff01;&#x1f604; 如果文章对你有帮助的话&#xff0c; 欢迎评论 &#x1f4ac;点赞&#x1f4…

微机原理——并行接口8255学习1

目录 并行接口特点 可编程并行接口芯片8255 8255端口地址 8255的三种工作方式 8255的两种命令&#xff08;方式命令和C端口命令&#xff09; 由用户扩展的并行接口8255的应用 声光报警器接口设计 步进电机控制接口设计 PA端口实现跑马灯 PB端口实现按键输入 并行接口特…

最大乘积分解(动态规划)

相较于我上一题写的动态规划&#xff0c;这一题比较简单 代码如下&#xff1a; #include<stdio.h>int main(void) {long long n, max[101] {0, 1};scanf("%lld", &n);for(int i 1; i < n; i)max[i] i;for(int i 1; i < n; i)for(int j 1; j &…

RT-Thread 汇编分析启动流程

文章目录 一、汇编指令二、启动文件三、流程图 一、汇编指令 这里介绍即几条最常见实用的汇编指令 LDR R0,[R1]&#xff1a;将R1指定内存地址数据&#xff0c;存储到寄存器R0中。STR R0,[R1,#4]&#xff1a;将寄存器R0中数据存储到寄存器R1加上偏移量4的位置。MOV r0,#0x01&a…

read()之后操作系统都干了什么

首先说明三个参数 file文件 buff从内存中开辟一段缓冲区用来接收读取的数据 size表示这个缓冲区的大小 有关file的参数&#xff1a; 状态&#xff1a;被打开 被关闭权限&#xff1a;可读可写最重要的是inode: 他包含了 文件的元数据(比如文件大小 文件类型 文件在访问前需要加…

Matlab和python详解数独谜题问题

&#x1f517; 运行环境&#xff1a;Matlab、Python &#x1f6a9; 撰写作者&#xff1a;左手の明天 &#x1f947; 精选专栏&#xff1a;《python》 &#x1f525; 推荐专栏&#xff1a;《算法研究》 &#x1f510;#### 防伪水印——左手の明天 ####&#x1f510; &#x1f4…

c语言调用free,提示已触发了一个断点。

在用c语言写数据结构的链表的时候&#xff0c;执行也没有什么大错&#xff0c;逻辑也是对的&#xff0c;但是一道free函数会自动触发一个断点。如图&#xff1a; 这个断点产生的原因是由于分配的内存太小了在使用的时候没有任何问题&#xff0c;但是在执行程序的时候&#xff0…

JAVA毕业设计113—基于Java+Springboot+Vue的体育馆预约系统(源代码+数据库+12000字论文)

基于JavaSpringbootVue的体育馆预约系统(源代码数据库12000字论文)113 一、系统介绍 本项目前后端分离&#xff0c;本系统分为管理员、用户两种角色 用户角色包含以下功能&#xff1a; 注册、登录、场地(查看/预订/收藏/退订)、在线论坛、公告查看、我的预订管理、我的收藏…

[二分查找]LeetCode2040:两个有序数组的第 K 小乘积

本文涉及的基础知识点 二分查找算法合集 题目 给你两个 从小到大排好序 且下标从 0 开始的整数数组 nums1 和 nums2 以及一个整数 k &#xff0c;请你返回第 k &#xff08;从 1 开始编号&#xff09;小的 nums1[i] * nums2[j] 的乘积&#xff0c;其中 0 < i < nums1.…

45 - 多线程性能优化常见问题

1、使用系统命令查看上下文切换 上下文切换常见的监测工具 1.1、Linux 命令行工具之 vmstat 命令 vmstat 是一款指定采样周期和次数的功能性监测工具&#xff0c;我们可以使用它监控进程上下文切换的情况。 vmstat 1 3 命令行代表每秒收集一次性能指标&#xff0c;总共获取 …

代码随想录算法训练营 ---第五十三天

第一题&#xff1a; 简介&#xff1a; 本题和昨天的最大重复子串问题很相似&#xff0c;只不过本题不一定是连续的。 动规五部曲分析如下&#xff1a; 确定dp数组&#xff08;dp table&#xff09;以及下标的含义 dp[i][j]&#xff1a;长度为i-1 的字符串text1与长度为j-1的…

智能优化算法应用:基于供需算法无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用&#xff1a;基于供需算法无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用&#xff1a;基于供需算法无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.供需算法4.实验参数设定5.算法结果6.参考文献7.MATLAB…

YoloV8改进策略:Swift Parameter-free Attention,无参注意力机制,超分模型的完美迁移

摘要 https://arxiv.org/pdf/2311.12770.pdf https://github.com/hongyuanyu/SPAN SPAN是一种超分网络模型。SPAN模型通过使用参数自由的注意力机制来提高SISR的性能。这种注意力机制能够增强重要信息并减少冗余,从而在图像超分辨率过程中提高图像质量。 具体来说,SPAN模…

Java三种代理模式:静态代理、动态代理和CGLIB代理

Java三种代理模式&#xff1a;静态代理、动态代理和CGLIB代理 代理模式 代理模式是23种设计模式种的一种。代理模式是一种结构型设计模式&#xff0c;它允许为其他对象提供一个替代品或占位符&#xff0c;以控制对这个对象的访问。代理模式可以在不修改被代理对象的基础上&am…

JavaScript基础知识20——循环结构:退出循环

哈喽&#xff0c;大家好&#xff0c;我是雷工&#xff01; 最近一段时间没学习JavaScript&#xff0c;今天看数字孪生的资料&#xff0c;发现很多低代码开发还是得必须熟悉JavaScript才行&#xff0c;为了以后方便搞数字孪生&#xff0c;有时间还是继续学习下JavaScript。 以下…

矩阵元素求和:按行、按列、所有元素np.einsum()

【小白从小学Python、C、Java】 【计算机等考500强证书考研】 【Python-数据分析】 矩阵元素求和&#xff1a; 按行、按列、所有元素 np.einsum() [太阳]选择题 下列说法正确的是&#xff1a; import numpy as np A np.array([[1, 2],[3, 4]]) print("【显示】A") p…

HR看好的字符函数和字符串处理函数!!!

本篇会加入个人的所谓‘鱼式疯言’❤️❤️❤️鱼式疯言:❤️❤️❤️此疯言非彼疯言,而是理解过并总结出来通俗易懂的大白话,我会尽可能的在每个概念后插入鱼式疯言,帮助大家理解的&#xff0c;可能说的不是那么严谨.但小编初心是能让更多人能接受我们这个概念 前言 在本篇…

【Google2023】利用TiDE进行长期预测实战(时间序列密集编码器)

一、本文介绍 大家好&#xff0c;最近在搞论文所以在研究各种论文的思想&#xff0c;这篇文章给大家带来的是TiDE模型由Goggle在2023.8年发布&#xff0c;其主要的核心思想是&#xff1a;基于多层感知机&#xff08;MLP&#xff09;构建的编码器-解码器架构&#xff0c;核心创…

【设计模式-4.3】行为型——责任链模式

说明&#xff1a;本文介绍设计模式中行为型设计模式中的&#xff0c;责任链模式&#xff1b; 审批流程 责任链模式属于行为型设计模式&#xff0c;关注于对象的行为。责任链模式非常典型的案例&#xff0c;就是审批流程的实现。如一个报销单的审批流程&#xff0c;根据报销单…