心链13---主页切换功能 + loading特效 + 导航栏完善 + 队伍页接口修改

心链 — 伙伴匹配系统

直接取出所有用户,依次和当前用户计算分数,取 TOP N(54 秒)

优化方法:

  1. 切忌不要在数据量大的时候循环输出日志(取消掉日志后 20 秒)
  2. Map 存了所有的分数信息,占用内存
    解决:维护一个固定长度的有序集合(sortedSet),只保留分数最高的几个用户(时间换空间)
    e.g.【3, 4, 5, 6, 7】取 TOP 5,id 为 1 的用户就不用放进去了
  3. 细节:剔除自己 √
  4. 尽量只查需要的数据:
  5. 过滤掉标签为空的用户 √
  6. 根据部分标签取用户(前提是能区分出来哪个标签比较重要)
  7. 只查需要的数据(比如 id 和 tags) √(7.0s)
  8. 提前查?(定时任务)
  9. 提前把所有用户给缓存(不适用于经常更新的数据)
  10. 提前运算出来结果,缓存(针对一些重点用户,提前缓存)

前端

一、主页切换功能

在vant组件库里寻找switch开关,复制到主页index里面
image.png
image.png
定义一个开关切换常量,默认为关闭

image.png

我们现在不需要一次性挂载,写一个加载的方法,并且写一个监听器(当开关切换时,“更换页面”)

/**
* 加载数据
*/const loadData = async () => {let userListData;// 心动模式,根据标签匹配用户if (isMatchMode.value) {const num = 10;userListData = await myAxios.get('/user/match', {params: {num,},}).then(function (response) {console.log('/user/match succeed', response);return response?.data;}).catch(function (error) {console.error('/user/match error', error);Toast.fail('请求失败');})} else {// 普通模式,直接分页查询用户userListData = await myAxios.get('/user/recommend', {params: {pageSize: 8,pageNum: 1,},}).then(function (response) {console.log('/user/recommend succeed', response);return response?.data?.records;}).catch(function (error) {console.error('/user/recommend error', error);Toast.fail('请求失败');})}if (userListData) {userListData.forEach((user: UserType) => {if (user.tags) {user.tags = JSON.parse(user.tags);}})userList.value = userListData;}}watchEffect(() => {loadData();})

PS:别忘了
image.png
,否则运行报错 但是添加之后user.tage会爆红,可以将UserType里的tags类型从数组改为字符串形式(这里爆红也能运行,所以就不更改了)
image.png
运行,页面显示如下 点击开关
image.png
image.png
中间加载的时间较长,这是正常现象

二、todo

image.png

1.加载loading特效

我们使用骨架屏特效
image.png
把它放在UserListCard里面(包裹内容)
image.png

别忘了在js里添加这两个参数
image.png
到index的user-card-list里引用
image.png
同时别忘了引入loading常量,并在loadData方法里,在开始和结尾处分别使loading设置为true和false
2.仅加入队伍和创建队伍的人能看到队伍操作按钮

队伍操作权限控制加入队伍: 仅非队伍创建人、且未加入队伍的人可见 更新队伍:仅创建人可见 解散队伍:仅创建人可见 退出队伍:创建人不可见,仅已加入队伍的人可见

仅加入队伍和创建队伍的人能看到队伍操作按钮(listTeam 接口要能获取我加入的队伍状态) 方案 1:前端查询我加入了哪些队伍列表,然后判断每个队伍 id 是否在列表中(前端要多发一次请求) 方案 2:在后端去做上述事情(推荐) 这里我们选择方案2

1.首先为TeamUserVO太那几是否已加入队伍的字段
image.png

2.修改listTeam的接口,加入是否已经加入队伍的判断
    @GetMapping("/list")public BaseResponse<List<TeamUserVO>> listTeams(TeamQuery teamQuery, HttpServletRequest request) {if (teamQuery == null) {throw new BusinessException(ErrorCode.PARAMS_ERROR);}boolean isAdmin = userService.isAdmin(request);// 1、查询队伍列表List<TeamUserVO> teamList = teamService.listTeams(teamQuery, isAdmin);final List<Long> teamIdList = teamList.stream().map(TeamUserVO::getId).collect(Collectors.toList());// 2、判断当前用户是否已加入队伍QueryWrapper<UserTeam> userTeamQueryWrapper = new QueryWrapper<>();try {User loginUser = userService.getLoginUser(request);userTeamQueryWrapper.eq("userId", loginUser.getId());userTeamQueryWrapper.in("teamId", teamIdList);List<UserTeam> userTeamList = userTeamService.list(userTeamQueryWrapper);// 已加入的队伍 id 集合Set<Long> hasJoinTeamIdSet = userTeamList.stream().map(UserTeam::getTeamId).collect(Collectors.toSet());teamList.forEach(team -> {boolean hasJoin = hasJoinTeamIdSet.contains(team.getId());team.setHasJoin(hasJoin);});} catch (Exception e) {}return ResultUtils.success(teamList);}
3.修改前端页面的user-card-list里4个按钮出现的判断条件
        <van-button size="small" type="primary" v-if="team.userId !== currentUser?.id && !team.hasJoin" plain@click="preJoinTeam(team)">加入队伍</van-button><van-button v-if="team.userId === currentUser?.id" size="small" plain@click="doUpdateTeam(team.id)">更新队伍</van-button><!-- 仅加入队伍可见 --><van-button v-if="team.userId !== currentUser?.id && team.hasJoin" size="small" plain@click="doQuitTeam(team.id)">退出队伍</van-button><van-button v-if="team.userId === currentUser?.id" size="small" type="danger" plain@click="doDeleteTeam(team.id)">解散队伍</van-button>
4.测试

我的数据库里有14队伍和24队伍,其中4是24的创建者,550007是14的创建者,同时4也是14的队员 ps:(写完后端千万别忘了重启)
image.png
image.png

对照要求,看看是否符合 (√)
image.png

5.前端导航栏死【标题】问题

解决:使用 router.beforeEach,根据要跳转页面的 url 路径 匹配 config/routes 配置的 title 字段 1.配置路由里的title字段
image.png
在BasicLayout里增加根据路由切换标题
image.png
同时把原来用于测试的Toast响应(请求成功)删除,全局搜索删除
在这里插入图片描述

别忘了,把这句也删除
image.png
刷新,切换到不同页面,测试标签栏是否更换,以及请求成功是否不再出现

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

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

相关文章

C++ | Leetcode C++题解之第140题单词拆分II

题目&#xff1a; 题解&#xff1a; class Solution { private:unordered_map<int, vector<string>> ans;unordered_set<string> wordSet;public:vector<string> wordBreak(string s, vector<string>& wordDict) {wordSet unordered_set(w…

SpringBoot+Vue网上购物商城系统(前后端分离)

技术栈 JavaSpringBootMavenMySQLMyBatisVueShiroElement-UI 系统角色对应功能 用户商家管理员 系统功能截图

docker部署redis实践

1.拉取redis镜像 # 拉取镜像 sudo docker pull redis2.创建映射持久化目录 # 创建目录 sudo mkdir -p $PWD/redis/{conf,data}3. 运行redis 容器&#xff0c;查看当前redis 版本号 # 运行 sudo docker run --name redis -d -p 6379:6379 redis # 查看版本号 sudo docker ex…

java异常处理知识点总结

一.前提知识 首先当运行出错的时候&#xff0c;有两种情况&#xff0c;一种叫做“错误”&#xff0c;另一种叫做“异常”。错误指的是运行过程中遇到了硬件或操作系统出错&#xff0c;这种情况程序员是没办法处理的&#xff0c;因为这是硬件和系统的问题&#xff0c;不能靠代码…

React Native中集成ArcGIS以显示地图、渲染自定义图层和获取地理信息数据

在您的数据采集上传的应用中集成ArcGIS以显示地图、渲染自定义图层和获取地理信息数据是一项常见需求。下面是如何实现这些功能的详细指南&#xff0c;包括具体步骤和示例代码。 1. 显示地图 原生开发 Android&#xff1a; 使用ArcGIS Android SDK。您需要在AndroidManifest…

tile-join的详细解释和使用说明

tile-join是Tippecanoe工具集中的一个实用命令&#xff0c;主要用于合并多个MBTiles文件&#xff0c;或者将属性数据添加到已有的MBTiles文件中。它可以处理大量的GeoJSON、Shapefile和MBTiles数据&#xff0c;并将它们合并成一个新的MBTiles文件。这对于需要结合多个数据源或者…

使用GPT-soVITS再4060下2小时训练声音模型以及处理断句带来的声音模糊问题

B站UP主视频 感谢UP主“白菜工厂1145号员工”的“熟肉”&#xff0c;我这篇笔记就不展示整一个训练和推理流程&#xff0c;重点写的4060该注意的一些事项。如何解决断句模糊的问题&#xff0c;在本篇笔记的最末尾。 相关连接&#xff1a; 原项目github UP主的说明文档 1、训…

如果一个列表有100000个数据,这个该怎么进行展示?

当列表包含大量数据&#xff08;如100,000个数据项&#xff09;时&#xff0c;直接渲染所有数据到DOM可能会导致性能问题&#xff0c;因为浏览器需要处理大量的DOM节点。为了优化这种情况&#xff0c;有几种常见的策略可以使用&#xff1a; 分页&#xff08;Pagination&#xf…

Python中的异常处理:try-except-finally详解与自定义异常类

Python中的异常处理&#xff1a;try-except-finally详解与自定义异常类 在Python编程中&#xff0c;异常处理是确保程序健壮性和可靠性的重要部分。当程序遇到无法预料的错误时&#xff0c;异常处理机制能够防止程序崩溃&#xff0c;并允许我们采取适当的措施来解决问题。本文…

Linux的目录结构介绍和环境变量的设置

目录 前言一、系统环境二、Linux的目录结构2.1 Linux目录结构介绍2.2 Linux文件的路径描述2.2.1 绝对路径2.2.2 相对路径2.2.3 特殊的路径符 三、Linux的环境变量设置3.1 环境变量PATH3.2 关于$符的使用3.3 环境变量的设置 总结 前言 本篇文章介绍Linux的目录结构和环境变量的…

相同的树-力扣

这道题目与堆成二叉树题目很相似&#xff0c;对称二叉树是每次传入的节点组合是 《左子树的左节点 和 右子树的 右节点》 《左子树的右节点 和 右子树的左节点》&#xff0c; 而这道题就更加简单&#xff0c;传入两棵树的左节点和右节点即可。 /*** Definition for a binary t…

[React]useEffect中return函数执行时机

已知在组件卸载时会执行return函数&#xff0c;其实在依赖项变更时也会执行。 import { useEffect, useState } from react;export default function HomePage() {const [count, setCount] useState(0);useEffect(() > {console.log(effect, count);return () > {conso…

【云原生Kubernetes项目部署】k8s集群+高可用负载均衡层+防火墙

目录 环境准备 拓朴图 项目需求 一、Kubernetes 区域可采用 Kubeadm 方式进行安装 1.1所有节点master、node01、node02 1.2所有节点安装docker 1.3所有节点安装kubeadm&#xff0c;kubelet和kubectl 1.4部署K8S集群 1.4.1复制镜像和脚本到 node 节点&#xff0c;并在 …

Excel数据自动检测,语音报警VBA代码,语音提醒

要实现这个功能&#xff0c;你可以使用以下VBA代码&#xff1a; 1. 首先&#xff0c;在Excel中插入一个ActiveX控件&#xff08;如"Microsoft Sound Control 6.0 (Spinner.Sound)"&#xff09;&#xff0c;并将其命名为"SoundControl"。 2. 然后&#xff0…

html--酷炫背景引导主页

<!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><title>ZZVIPS酷炫背景引导主页</title><meta name"viewport" content"widthdevice-width,initial-scale1,maximum-scale1,user-scala…

Python 模块完全指南:从基础语法到高级应用的全方位解析

基本语法 在 Python 中&#xff0c;模块是一种包含 Python 代码的文件&#xff0c;用于组织和重用代码。模块可以包含变量、函数、类等&#xff0c;并且可以被其他 Python 程序导入和使用。 1. 导入模块 要使用一个模块&#xff0c;需要使用 import 关键字将其导入到当前的 …

jquery.datetimepicker控件不弹出的问题

项目场景&#xff1a; CRM项目&#xff0c;在项目中涉及日期类输入框&#xff0c;打算采用平常见到的点击选择日期的方式。在浏览了网页后&#xff0c;目前比较好的解决方案是jquery.datetimepicker和flatpicker两种&#xff0c;flatpicker的缺点是官网是英文版的&#xff0c;…

Android 13.0 Launcher3单层模式workspace中app列表页排序功能实现

1.概述 在13.0的定制化开发中,对于Launcher3的功能定制也是好多的,而对于单层app列表页来说排序功能的开发,也是常有的功能这就需要了解加载app数据的流程,然后根据需要进行排序就可以了,接下来就来实现这个功能 如图: 2. Launcher3单层模式workspace中app列表页排序功能…

【漏洞复现】Apache OFBiz 路径遍历导致RCE漏洞(CVE-2024-36104)

0x01 产品简介 Apache OFBiz是一个电子商务平台&#xff0c;用于构建大中型企业级、跨平台、跨数据库、跨应用服务器的多层、分布式电子商务类应用系统。是美国阿帕奇(Apache)基金会的一套企业资源计划(ERP)系统。该系统提供了一整套基于Java的Web应用程序组件和工具。 0x02 …

EntitiesSample_7. EnableableComponents

该示例只要表达的是关闭和激活组件&#xff0c;之前的示例我们知道对于一个ECS组件需要继承IComponent接口,说明这个是一个组件&#xff0c;数组的话需要继承IBufferElementData接口&#xff0c;说明这个是一个数组元组组件&#xff0c;如果需要组件的激活控制&#xff0c;结构…