【开源】基于Vue.js的中学生家校互联系统

在这里插入图片描述
文末获取源码,项目编号: S 071 。 \color{red}{文末获取源码,项目编号:S071。} 文末获取源码,项目编号:S071


目录

  • 一、摘要
    • 1.1 项目介绍
    • 1.2 项目录屏
  • 二、功能模块
    • 2.1 学生管理模块
    • 2.2 课堂表现模块
    • 2.3 考试成绩模块
    • 2.4 家校留言模块
    • 2.5 校园通知模块
  • 三、系统设计
    • 3.1 用例设计
    • 3.2 实体类设计
      • 3.2.1 课堂表现实体类设计
      • 3.2.2 考试成绩实体类设计
      • 3.2.3 家校留言实体类设计
      • 3.2.4 校园通知实体类设计
      • 3.2.5 学生实体类设计
  • 四、系统展示
  • 五、核心代码
    • 5.1 新增作业提交
    • 5.2 查询考试成绩
    • 5.3 新增家校留言
    • 5.4 查询学生
    • 5.5 查询校园通知
  • 六、免责说明


一、摘要

1.1 项目介绍

基于JAVA+Vue+SpringBoot+MySQL的中学生家校互联系统,包含了学生档案模块、考试成绩模块、作业模块、课堂表现模块、校园通知模块、家校留言模块,还包含系统自带的用户管理、部门管理、角色管理、菜单管理、日志管理、数据字典管理、文件管理、图表展示等基础模块,中学生家校互联系统基于角色的访问控制,给管理员、学生家长、教师使用,可将权限精确到按钮级别,您可以自定义角色并分配权限,系统适合设计精确的权限约束需求。

1.2 项目录屏

源码下载


二、功能模块

家校互联系统的功能性需求主要包含学生管理模块、角色管理模块、课程档案模块、家校位置模块和家校申请模块这五大模块,系统是基于浏览器运行的web管理后端,其中各个模块详细说明如下。

在这里插入图片描述

2.1 学生管理模块

家校互联模式需要学生管理模块的原因主要有以下几个方面,学生管理模块可以将学生的基本信息、成绩、出勤情况等重要信息同步到家长端和教师端,方便家长和教师随时了解学生的学习状况。学生管理模块能够支持教师进行课程设置、作业布置、成绩录入等多种教学管理操作,提升教学效率和质量。学生管理模块可以加强对学生身份、学籍等信息的管理与保护,避免信息泄露或者被恶意利用。学生管理模块能够建立和维护学生的电子档案,包括学籍信息、成长轨迹、奖惩记录等,方便家长和教师对学生进行全面的评估和跟踪。总之,学生管理模块是家校互联模式中不可或缺的一部分,其功能和作用不仅仅是简单的数据管理,更是涉及到学生教育的方方面面,能够为家长、教师和学生之间的沟通和协作提供强有力的支持。

2.2 课堂表现模块

家校互联系统需要课堂表现模块,课堂表现模块可以反映学生的真实表现。课堂表现模块可以记录学生在课堂上的发言、提问、回答问题等行为,反映学生的真实表现和参与度。这对于了解学生的学习情况和评价学生的综合素质具有重要作用。课堂表现模块可以便于教师评价学生,通过课堂表现模块,教师可以及时记录学生的表现,评价学生的优点和不足,为学生提供更加精准的评价和指导。课堂表现模块可以增强家长对学生的了解,通过家校互联系统的课堂表现模块,家长可以了解自己孩子在课堂上的表现和参与情况,掌握孩子的学习状况,为孩子提供更好的学习支持和帮助。课堂表现模块可以促进学校和家长的沟通,课堂表现模块可以作为家校联系的重要内容之一,让学校和教师与家长分享学生的表现和成长情况,促进学校和家长之间的沟通和合作。因此,课堂表现模块是家校互联系统中不可或缺的一部分,它可以为学生、教师和家长提供更加全面和有效的服务。

2.3 考试成绩模块

家校互联系统需要考生成绩模块的原因如下,考生成绩模块可以及时反馈学生成绩,通过考生成绩模块,教师可以及时将学生的考试成绩反馈给家长,让家长及时了解孩子在学习上的表现。考生成绩模块可以分析学生学习情况,通过考生成绩模块,可以对学生的成绩进行统计和分析,发现学生的学习情况和问题,及时采取措施加以改善。考生成绩模块可以提高学生的学习动力,学生可以通过考生成绩模块随时查询自己的考试成绩,了解自己的学习情况,并根据成绩反思自己的学习方法和策略,提高学习动力和主动性。考生成绩模块可以促进家校交流,通过考生成绩模块,家长可以更加清楚地了解孩子的学习情况和成绩,与教师进行更加深入的交流和沟通,共同关注孩子的学业和生活。考生成绩模块可以进行教学管理和评估,学校和教育部门可以通过考生成绩模块进行教学管理和评估,了解学校和教师的教育质量和水平,指导教学改革和发展。

2.4 家校留言模块

家校互联系统需要家校留言模块,是因为家长和教师之间的沟通非常重要,而家校留言模块可以提供一种方便、快捷、实时的沟通方式。首先,家校留言模块可以让家长在工作繁忙的情况下,通过网络随时向教师咨询学生的学习状况或者向学校反映孩子的问题。这样就不必等到家长会或者面谈才能解决问题,节约了时间和精力。其次,教师也可以通过家校留言模块及时回复家长的问题或者建议,了解家长对学校和教育工作的看法和建议。这样可以增强教师和家长之间的沟通,共同关注孩子的学业和生活,提高教育质量。最后,家校留言模块还可以记录家长和教师之间的交流内容,有利于形成有效的信息记录和管理,以便更好地跟进与解决问题。综上所述,家校留言模块是家校互联系统中非常重要的一个模块,它可以促进家庭教育和学校教育的有效衔接,提高家长和教师之间的沟通效率和质量,为孩子的成长和发展提供有力的支持。

2.5 校园通知模块

家校互联系统需要校园通知模块,因为校园通知可以及时传递信息,校园通知模块可以在第一时间向学生、家长和教师发送重要信息和通知,如课程调整、考试安排、活动通知等,让每一个人都能及时了解相关情况,避免错过重要事项。校园通知方便快捷,相比传统的通知方式,如纸质文件或电话通知,校园通知模块更加方便快捷,可以随时随地通过手机或电脑进行查看和处理,尤其适用于紧急情况下的通知。校园通知可以精准定位目标群体,校园通知模块可以根据不同的角色设置不同的接收对象,如学生、家长、教师等,可以精准地定位目标群体,避免信息传递的混乱和误解。校园通知可以提高工作效率,校园通知模块可以将大量工作自动化,如批量发送通知、自动生成报表等,可以大大提高工作效率和准确性,降低工作负担。总之,校园通知模块是家校互联系统的重要组成部分,它可以为学校、教师和家长提供快捷、准确的信息传递方式,提高教育管理效率和质量。


三、系统设计

3.1 用例设计

在这里插入图片描述

3.2 实体类设计

3.2.1 课堂表现实体类设计

在这里插入图片描述

3.2.2 考试成绩实体类设计

在这里插入图片描述

3.2.3 家校留言实体类设计

在这里插入图片描述

3.2.4 校园通知实体类设计

在这里插入图片描述

3.2.5 学生实体类设计

在这里插入图片描述


四、系统展示

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


五、核心代码

5.1 新增作业提交

@RequestMapping(value = "/insert", method = RequestMethod.POST)
@ApiOperation(value = "新增作业提交")
public Result<Assignment> insert(Assignment assignment){
    MyStudent s = iMyStudentService.getById(assignment.getStuId());
    if(s == null) {
        return ResultUtil.error("学生不存在");
    }
    assignment.setStuName(s.getName());
    assignment.setDate(DateUtil.today());
    iAssignmentService.saveOrUpdate(assignment);
    return new ResultUtil<Assignment>().setData(assignment);
}

5.2 查询考试成绩

@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询考试成绩")
public Result<IPage<ExamScores>> getByPage(@ModelAttribute ExamScores examScores ,@ModelAttribute PageVo page){
    QueryWrapper<ExamScores> qw = new QueryWrapper<>();
    User currUser = securityUtil.getCurrUser();
    User user = iUserService.getById(currUser.getId());
    QueryWrapper<User> userQw = new QueryWrapper<>();
    userQw.eq("id",user.getId());
    userQw.inSql("id","SELECT user_id FROM a_user_role WHERE del_flag = 0 AND role_id = '1536606659751841799'");
    if(iUserService.count(userQw) < 1L) {
        qw.eq("stu_id",user.getMyStudent());
    }
    if(!ZwzNullUtils.isNull(examScores.getTitle())) {
        qw.like("title",examScores.getTitle());
    }
    if(!ZwzNullUtils.isNull(examScores.getContent())) {
        qw.like("content",examScores.getContent());
    }
    IPage<ExamScores> data = iExamScoresService.page(PageUtil.initMpPage(page),qw);
    return new ResultUtil<IPage<ExamScores>>().setData(data);
}

5.3 新增家校留言

@RequestMapping(value = "/insert", method = RequestMethod.POST)
@ApiOperation(value = "新增家校留言")
public Result<Message> insert(Message message){
    User currUser = securityUtil.getCurrUser();
    message.setUserId(currUser.getId());
    message.setUserName(currUser.getNickname());
    message.setTime(DateUtil.now());
    message.setReplyContent("");
    message.setReplyId("");
    message.setReplyName("");
    message.setReplyTime("");
    iMessageService.saveOrUpdate(message);
    return new ResultUtil<Message>().setData(message);
}

5.4 查询学生

@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询学生")
public Result<IPage<MyStudent>> getByPage(@ModelAttribute MyStudent myStudent ,@ModelAttribute PageVo page){
    QueryWrapper<MyStudent> qw = new QueryWrapper<>();
    if(!ZwzNullUtils.isNull(myStudent.getName())) {
        qw.like("name",myStudent.getName());
    }
    if(!ZwzNullUtils.isNull(myStudent.getLevel())) {
        qw.like("level",myStudent.getLevel());
    }
    IPage<MyStudent> data = iMyStudentService.page(PageUtil.initMpPage(page),qw);
    return new ResultUtil<IPage<MyStudent>>().setData(data);
}

5.5 查询校园通知

@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询校园通知")
public Result<IPage<News>> getByPage(@ModelAttribute News news ,@ModelAttribute PageVo page){
    QueryWrapper<News> qw = new QueryWrapper<>();
    if(!ZwzNullUtils.isNull(news.getTitle())) {
        qw.like("title",news.getTitle());
    }
    if(!ZwzNullUtils.isNull(news.getContent())) {
        qw.like("content",news.getContent());
    }
    IPage<News> data = iNewsService.page(PageUtil.initMpPage(page),qw);
    return new ResultUtil<IPage<News>>().setData(data);
}

六、免责说明

  • 本项目仅供个人学习使用,商用授权请联系博主,否则后果自负。
  • 博主拥有本软件构建后的应用系统全部内容所有权及独立的知识产权,拥有最终解释权。
  • 如有问题,欢迎在仓库 Issue 留言,看到后会第一时间回复,相关意见会酌情考虑,但没有一定被采纳的承诺或保证。

下载本系统代码或使用本系统的用户,必须同意以下内容,否则请勿下载!

  1. 出于自愿而使用/开发本软件,了解使用本软件的风险,且同意自己承担使用本软件的风险。
  2. 利用本软件构建的网站的任何信息内容以及导致的任何版权纠纷和法律争议及后果和博主无关,博主对此不承担任何责任。
  3. 在任何情况下,对于因使用或无法使用本软件而导致的任何难以合理预估的损失(包括但不仅限于商业利润损失、业务中断与业务信息丢失),博主概不承担任何责任。
  4. 必须了解使用本软件的风险,博主不承诺提供一对一的技术支持、使用担保,也不承担任何因本软件而产生的难以预料的问题的相关责任。

你可能感兴趣的:(java,vue.js,开源,javascript)