当前位置: 首页 > article >正文

高并发下的列表乱序与文档同步

一、整体工作概述今天主要完成了一点bug修复高并发点击的时候列表会乱序以及ai coding实现文档的CRUD同时文档列表要同步渲染。这一大块是ai写的我只是看懂了代码整体技术难度不高而且一部分实现方式比较简单粗暴后面还有优化空间。简单记录一下开发过程作为个人学习与复盘。二、列表顺序随机跳变 bug 修复服务端非确定性行为与前端过度请求交织产生的 Bug服务端存在非确定性行为导致前端频繁点击时骨架屏上的列表顺序会突然打乱出现数据顺序随机跳变的 bug。问题的本质是后端数据库查询时没有显式指定排序例如按照什么sort所以数据库返回数据的顺序没有强制保证在高并发多次连接或缓存刷新时顺序就会随机跳变。bug解决方案是是把下列useEffect删掉就好了。useEffect((){if(currentId){fetchDocs(false);}},[currentId,fetchDocs]);为什么删除那个 useEffect 之后选中文档列表的高亮还在但乱序消失了高亮逻辑的真相 isActive doc._id currentId。这里的 currentId 来自 URLuseParams。当点击 Maps 时URL 变了React 会触发 WikiList 组件重新渲染。此时 docs 数组依然存在于内存中State 未变React 只需要重新计算每个 Item 的 isActive 布尔值并刷新 DOM 即可。根本不需要重新拉取数据。乱序消失的真相 既然不再触发 getAllDocuments也就没有了后端随机排序的干扰前端始终持有第一次加载时第一个 useEffect拿到的那份数据。也就是说前端连击触发 map导致 current ID 改变没法正常拿到后端数据后端又重新返回一遍列表数据把顺序打乱了。我每次都会触发全量数据拉取后端又没有强制排序数据顺序本身就不可靠再加上 useEffect 频繁监听请求拿到新顺序后重新渲染最终导致列表顺序错乱。这里我用 Network 面板验证看了名为 documents 的请求响应联机时能观察到同一个 ID 的元素位置在变化。删掉这个 useEffect不再触发 getAllDocuments 请求不重新拉取数据避开后端随机排序的影响直接保留第一次加载的数据就行。三、删除文档功能实现与疑问在这之后我做了第二个功能这个功能是 AI 实现的我只是把代码看了一遍看懂后做了删除相关的操作。我最初理解的全栈开发思路首先在前端 API 服务层新增一个删除文档的接口供调用前端 UI 事件触发时在 onClick 里绑定这个 API 服务向后端发请求。后端收到请求后在 controller 层执行删除文件的指令并新增对应的删除路由。简化流程即前端 UI 绑定事件 → 事件触发请求 → 请求经前端 API 服务层发给后端 → 后端 controller 响应 → 路由分发 → 对数据库做 CRUD 操作。这里我有个疑问为什么后端新增路由就能直接操作数据库是怎么直接连上数据库的为什么现在后端的 POST、PUT、DELETE 这些路由都能直接操作数据库经过梳理完整的全栈开发思路是前端 UI 绑定事件并触发 API 请求请求经网络到达后端由 “预设” 好的路由进行分发并指派给对应的控制器Controller控制器调用 “启动时已建立” 的数据库连接借助.env 配置加载最终完成对数据库的 CRUD 操作。1. 前端层定义与触发API 服务层定义先在前端 src/api 里写好“删除文档”的接口函数比如用 axios.delete明确告诉浏览器我们要去哪个 URL、带哪个 id、用什么姿势DELETE 方法发请求。UI 事件绑定在 React 组件的按钮 onClick 里直接绑定这个 API 函数。当用户一点封装好的请求就带着数据“起飞”穿过网络直奔后端。2. 后端层接线与派发路由分发 (Routing)这里要注意后端是预先埋伏好路由的。请求一到路由就像个“接线员”看一眼方法DELETE和路径立刻把这个请求“踢”给对应的 Controller。Controller 响应Controller 才是真正的大脑。它负责把请求里的 id 摘出来检查用户有没有权限删然后下达最终的“处决指令”。3. 持久层指令执行数据库 CRUDController 调用数据库工具比如 Mongoose 或 Prisma利用早已建立好的连接管道对数据库执行真正的删除动作。Q1为什么后端“配个路由”就能直接操作数据库路由只是“门牌号”不是“推土机”。你之所以觉得“配了路由就能删”是因为你在写 router.delete() 的时候紧跟着在回调函数里写了操作数据库的代码。路由负责确定“哪个接口对应哪个功能”。Controller 负责在这个功能里真正去改数据库。Q2后端是怎么“直接”连上数据库的连接发生在服务器启动的一瞬间而不是请求来的时候。当你运行后端项目比如 npm run dev时程序会立刻读取 .env 里的数据库地址和密码跟数据库建立一个持久的连接池。平时连接管道是通的处于待命状态。请求来时Controller 只是顺着这个现成的“水管”发了一条指令速度极快。Q3为什么现在的 POST、PUT、DELETE 路由都能操作数据库这是一种语义化约定 (RESTful)而不是物理限制。从技术底层看它们都是 TCP 数据包本质没区别。但为了让代码好维护DELETE约定用来删逻辑上直观。POST/PUT约定用来增和改因为它们可以往请求体Body里塞进复杂的 JSON 结构方便 Controller 拿到完整的数据去更新数据库。四、细节优化与体验改进还有一个细节问题新增和删除文件时左侧 wiki list 整个文档列表没有跟着数据动态更新。当前处理方式是在 window 上挂载事件监听器定义 DOCUMENTS_CHANGED_EVENT 处理文档变化。exportconstDOCUMENTS_CHANGED_EVENTdocuments:changed;exportconstnotifyDocumentsChanged(){window.dispatchEvent(newEvent(DOCUMENTS_CHANGED_EVENT));};useEffect((){consthandleDocumentsChanged(){fetchDocs();};window.addEventListener(DOCUMENTS_CHANGED_EVENT,handleDocumentsChanged);return(){window.removeEventListener(DOCUMENTS_CHANGED_EVENT,handleDocumentsChanged,);};},[fetchDocs]);我觉得这个方式虽然清晰但直接操作 DOM、挂载到 window 上跳出了 React 框架算不上优雅实现简单但有点粗暴后面可能会再改想想怎么放到现有框架里方便调试和维护。另外还有 UX 细节比如删除当前文件后不想显示空白占位 UI希望自动打开列表里下一个文档。这里用了 if 判断定义了 remainingDocs逻辑大概是如果还有数据就从数组里依次读 ID 做路由跳转constremainingDocsawaitgetAllDocuments();if(remainingDocsremainingDocs.length0){navigate(/wiki/${remainingDocs[0]._id});}else{navigate(/wiki);}只有数据全空时才展示空白占位 UI。还有一些警示弹窗就是调用组件库组件Modal再配合国际化没什么难度。五、小结今天做的工作难度不算大解决问题的一些方案也比较粗暴不够优雅。后面我会再想想更合适的实现方式对架构的理解要更多一些加油加油参考文档使用 Fetch - Web API | MDNString.prototype.localeCompare() - JavaScript | MDNArray.prototype.sort() - JavaScript | MDNEventTarget.dispatchEvent() - Web API | MDN​

相关文章:

高并发下的列表乱序与文档同步

一、整体工作概述 今天主要完成了一点bug修复,高并发点击的时候列表会乱序,以及ai coding实现文档的CRUD,同时文档列表要同步渲染。 这一大块是ai写的,我只是看懂了代码,整体技术难度不高,而且一部分实现方…...

uniapp集成支付宝授权登录全流程指南(附iOS/Android适配方案)

uniapp集成支付宝授权登录全流程指南(附iOS/Android适配方案) 在移动应用开发中,第三方登录已经成为提升用户体验的重要功能之一。支付宝作为国内主流的支付平台,其授权登录功能被广泛应用于各类APP中。本文将详细介绍如何在unia…...

避坑指南:STM32F407开发中那些容易翻车的细节(GPIO消抖/FSMC配置/CAN总线调试)

STM32F407实战避坑手册:GPIO消抖、FSMC配置与CAN总线调试精要 从事嵌入式开发多年,我见过太多工程师在STM32F407项目开发中反复踩同样的坑。本文将聚焦三个最容易出问题的技术点——GPIO消抖、FSMC接口配置和CAN总线调试,结合真实项目案例&am…...

OSX-KVM PCI设备直通详解:从网卡到GPU全攻略

OSX-KVM PCI设备直通详解:从网卡到GPU全攻略 【免费下载链接】OSX-KVM Run macOS on QEMU/KVM. With OpenCore Big Sur Monterey Ventura support now! Only commercial (paid) support is available now to avoid spammy issues. No Mac system is required. …...

3分钟搞定网易云音乐插件安装:BetterNCM Installer终极指南

3分钟搞定网易云音乐插件安装:BetterNCM Installer终极指南 【免费下载链接】BetterNCM-Installer 一键安装 Better 系软件 项目地址: https://gitcode.com/gh_mirrors/be/BetterNCM-Installer BetterNCM Installer是网易云音乐PC版客户端的最佳插件管理器安…...

从硬件到软件:用示波器抓取分析MCU启动波形的完整教程

从硬件到软件:用示波器抓取分析MCU启动波形的完整教程 当一块微控制器(MCU)从冷启动到正常运行,其内部经历了一系列精密的"唤醒仪式"。对于硬件开发者而言,能够亲眼目睹这一过程就像获得了诊断系统健康的X光…...

【企业级API协议选型终极指南】:基于金融/物联网/实时音视频三大场景的MCP落地决策树

第一章:MCP协议与传统REST API性能对比概览MCP(Message-Centric Protocol)是一种面向高吞吐、低延迟场景设计的二进制消息协议,其核心理念是通过紧凑序列化、连接复用与无状态批量交互,显著降低网络往返与解析开销。相…...

GitHub Linguist自动化测试框架:CI环境中的集成方法

GitHub Linguist自动化测试框架:CI环境中的集成方法 【免费下载链接】linguist Language Savant. If your repositorys language is being reported incorrectly, send us a pull request! 项目地址: https://gitcode.com/GitHub_Trending/li/linguist GitHu…...

基于多种天气因素的光伏电站太阳能辐射量预测系统——采用人工神经网络与离线优化算法

MATLAB代码:考虑多种天气条件下光伏电站太阳能辐射量预测 关键词:辐射量预测 光伏预测 多种天气因素 参考文档:《Solar Radiation Prediction and Energy Allocation for Energy Harvesting Base Stations》 仿真平台:MATLABCPLE…...

别再手动画图了!用Coze+TreeMind,5分钟搞定ISO标准流程图和思维导图

告别低效绘图:AI双引擎如何重塑你的视觉化工作流 在知识经济时代,信息可视化能力已成为职场核心竞争力。国际数据公司(IDC)研究显示,专业工作者平均每周耗费4.7小时在图表制作上,其中72%的时间用于机械性的…...

Kubernetes 1.28 集群架构深入解析:从基础到企业级部署

文章目录 🌐 Kubernetes 1.28 集群架构深度解析:从基础到企业级部署 ✅ 前言:云原生时代的操作系统 一、Kubernetes 1.28 集群架构全景图 1.1 核心设计哲学:声明式、期望状态、控制器模式 1.2 架构演进:从单节点到全球分布式集群 1.3–1.5 架构组件全景(统一图谱) 二、…...

[SWPUCTF 2025 秋季新生赛]ezez_include两种解题思路

方法一:日志文件包含一开始考虑的是文件上传,dirsearch扫描出来有upload页面结果根据响应页面这个版本的文件上传漏洞完全做不出来,服务器解析不了换个思路,文件包含利用日志包含漏洞什么是日志包含漏洞:就是把恶意代码…...

Spring Boot + Vue3 社区生鲜团购系统源码(Java Web全栈开发)

温馨提示:文末有联系方式全新升级版生鲜团购系统源码 本套Java Web全栈项目基于Spring Boot后端框架与Vue3前端框架深度整合,专为社区生鲜团购场景定制开发,代码结构清晰、注释完整、功能完备,非网上泛滥的廉价模板,品…...

OpenClaw+LibTV = 真正意义的一站式短剧自动生成

当你的手中有了OpenClaw,并为他创建了机器人,用它做了很多纯文本的工作,还不知足?你想着去用它接入豆包生成图片,接入Seedance生成视频,巴拉巴拉折腾好一顿,光是网站都要打开好多个,…...

CH32V307 - SPI基础时序详解

目录 前言 一、SPI概念 1.接口说明 2.时序实现 3.应用方法 二、基础时序实现代码 1.IO口读写操作 2.SPI对应IO口初始化 3.SPI开始时序 4.SPI终止时序 5.SPI交换一个字节 三、函数调用 四、实验现象 五、完整代码 main.c SPI.c SPI.h Key.c / Key.h LED.c / L…...

终极指南:如何使用Legacy iOS Kit让旧iPhone/iPad重获新生

终极指南:如何使用Legacy iOS Kit让旧iPhone/iPad重获新生 【免费下载链接】Legacy-iOS-Kit An all-in-one tool to downgrade/restore, save SHSH blobs, and jailbreak legacy iOS devices 项目地址: https://gitcode.com/gh_mirrors/le/Legacy-iOS-Kit 你…...

All-In-One Sandbox:Agent自动化任务的统一执行环境

All-In-One Sandbox:Agent自动化任务的统一执行环境 当你的Agent需要同时操作浏览器、执行代码、运行Shell命令来完成一个任务时,是否曾陷入这样的困境:浏览器下载的文件要上传到云存储,代码沙箱才能读取;代码生成的结果又要重新上传,供下一个工具使用……这种“文件共享…...

上位机开发初体验|第一个项目从 0 到 1:项目创建与整体 UI 布局

作为上位机开发的新手,我的第一个项目从基础的项目搭建和 UI 布局开始入手,这一步也是整个项目的基础,做好窗体、容器、控件的基础样式配置,能为后续的功能开发打下整洁的框架。以下是我整理的详细操作步骤,亲测实用&a…...

最新!OpenClaw 2026年云端与本地Windows11、macOS、Linux系统安装及使用零技术步骤

最新!OpenClaw 2026年云端与本地Windows11、macOS、Linux系统安装及使用零技术步骤。本文面向零基础用户,完整说明在轻量服务器与本地Windows11、macOS、Linux系统中部署OpenClaw(Clawdbot)的流程,包含环境配置、服务启…...

API平台选型指南:从RapidAPI到幂简集成,如何为你的项目精准匹配?

1. 为什么API平台选型如此重要? 想象一下你正在开发一个本地生活应用,需要整合支付、地图和AI能力。如果每个功能都从零开发,光是支付系统可能就要耗费半年时间。而通过API平台,你可以在几小时内接入成熟的支付宝接口,…...

光学设计必知:Ansys Zemax中6种系统孔径类型的适用场景全解析

Ansys Zemax系统孔径类型深度解析:从基础原理到高阶应用 在光学系统设计中,系统孔径的设定如同为整个光学系统划定"通行规则",它决定了哪些光线能够参与成像,哪些将被排除在外。Ansys Zemax作为业界领先的光学设计软件&…...

OSX-KVM网络流量监控:使用Wireshark分析虚拟机通信

OSX-KVM网络流量监控:使用Wireshark分析虚拟机通信 【免费下载链接】OSX-KVM Run macOS on QEMU/KVM. With OpenCore Big Sur Monterey Ventura support now! Only commercial (paid) support is available now to avoid spammy issues. No Mac system is requir…...

ESP32 C3按键唤醒终极指南:MicroPython固件修改与实战代码分享

ESP32 C3按键唤醒终极指南:MicroPython固件修改与实战代码分享 当你的ESP32 C3设备需要依靠纽扣电池运行数月甚至数年时,睡眠模式就成为了救命稻草。但官方MicroPython固件在C3型号上的按键唤醒功能存在严重缺陷——这个发现让我在凌晨三点的实验室里既崩…...

AI 产品岗转技术岗:零基础学习路径与面试避坑指南

一、转岗前期:先想清楚3个核心问题 很多AI产品经理转技术岗的初衷,要么是觉得产品工作"不落地",要么是想深入技术核心提升竞争力,但转岗不是拍脑袋决定的,必须先明确三个问题: 你要转哪个细分技术…...

Vue3新手避坑指南:从Element Plus到axios拦截器的5个实用技巧

Vue3实战避坑手册:Element Plus与axios拦截器的高效配置策略 作为一名从后端转型全栈开发的工程师,我深刻理解在Vue3入门阶段遇到的种种困惑。本文将分享五个关键场景的解决方案,这些正是我在实际项目中踩过坑后总结的精华。 1. Element Pl…...

Rolldown包体积优化:从1MB到100KB的蜕变之旅

Rolldown包体积优化:从1MB到100KB的蜕变之旅 【免费下载链接】rolldown Modern bundler built on Rollup with couple more features, such as multiple entry points, presets, better configuration experience and more. 项目地址: https://gitcode.com/GitHub…...

从Hugging Face到ModelScope:手把手教你迁移训练好的模型并部署推理服务

从Hugging Face到ModelScope:模型迁移与生产化部署实战指南 当你在Hugging Face生态中完成模型训练后,如何将其转化为可稳定服务的产品级应用?ModelScope作为国产化的模型服务平台,为模型工程化提供了完整的解决方案。本文将带你深…...

FPGA嵌入式开发中8类主流I/O标准选型指南

1. 番外篇:I/O Type 扩展知识详解在嵌入式硬件开发,尤其是基于FPGA的可编程逻辑系统设计中,I/O电气标准(I/O Type)远非简单的“高电平/低电平”二值抽象。它是连接芯片内部逻辑与外部物理世界的桥梁,直接决…...

Q-Learning在游戏AI中的5个实战技巧:从贪吃蛇到Flappy Bird

Q-Learning在游戏AI中的5个实战技巧:从贪吃蛇到Flappy Bird 当我在大学第一次用Q-Learning训练贪吃蛇AI时,那个笨拙的小蛇总是不停地撞墙。经过72小时的参数调整后,它终于能吃掉屏幕上90%的苹果——这个经历让我深刻体会到,在游戏…...

MapLibre Native核心架构解析:深入理解矢量瓦片渲染机制

MapLibre Native核心架构解析:深入理解矢量瓦片渲染机制 【免费下载链接】maplibre-native MapLibre Native - Interactive vector tile maps for iOS, Android and other platforms. 项目地址: https://gitcode.com/GitHub_Trending/ma/maplibre-native Map…...