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

第 17 课:任务选择与批量操作

第 17 课任务选择与批量操作这一课我们继续把任务页做得更像真实后台系统。上一课我们已经完成了单条任务删除危险操作确认框局部更新和局部删除这一课继续升级加入两个在真实项目里非常常见的能力勾选多条任务对已勾选任务执行批量操作这一步很重要因为它会让你第一次明显感受到“单条操作”只关心一个目标“批量操作”要先管理一组目标一旦要管理“一组目标”页面状态就会显著复杂起来这节课解决了什么问题在没有“选择状态”之前页面只能做这种事点“编辑”处理一条任务点“删除”处理一条任务但真实项目里经常会出现这样的需求一次选中多条任务一次全部标记完成一次全部删除只选当前页清空当前选择这时候页面必须回答几个新问题哪些任务被选中了当前页是不是全选当前页是不是半选批量操作后要不要清空选择如果当前正在编辑的任务也被批量改动了该怎么办所以这节课的核心不只是“多几个按钮”而是批量操作 选择状态管理 页面级行为协调 组件展示联动这节课新增了哪些东西1. 页面级选择状态文件src/composables/useTasksPage.ts这里新增了几个核心状态selectedTaskIdsselectedTasksselectedTaskCountselectedCurrentPageTaskCountisCurrentPageFullySelectedisCurrentPagePartiallySelected你可以把它们理解成两层第一层是“原始状态”selectedTaskIds第二层是“派生状态”当前一共选中多少条当前页选中多少条当前页是不是全选当前页是不是半选这正是 Vue 里很常见的模式ref存原始状态computed算派生状态。2. 单条勾选和本页全选文件src/composables/useTasksPage.tssrc/components/tasks/TaskTable.vuesrc/components/tasks/TaskBatchActionsBar.vue这节课有两个选择入口表格每一行前面的复选框“选中当前页”复选框对应的方法是handleTaskSelectionChangehandleCurrentPageSelectionChange这两个方法都没有直接写在页面里而是放进了useTasksPage。原因很简单勾选状态属于页面状态不是某一个按钮自己的局部状态既要被表格用也要被批量操作栏用所以它更适合放在页面级 composable 里统一维护。3. 批量操作栏组件新文件src/components/tasks/TaskBatchActionsBar.vue这个组件只负责做三件事显示当前已选数量显示当前页数量抛出批量操作事件它本身不保存任务数据也不保存任务数组。这说明一个非常重要的前端设计原则展示组件尽量只负责展示和抛事件状态尽量由页面层统一维护。这样做有两个好处组件职责更单纯后面更容易复用为什么批量操作要继续放在页面层协调批量完成completeSelectedTasks()写在useTasksPage里。它负责找出选中的任务过滤掉本来就已完成的任务本地更新状态调用服务层同步写回清空选择但是“提示用户成功了几条”“如果没有任何有效任务该怎么提示”这些仍然放在src/views/TasksView.vue原因是这属于页面交互反馈不属于纯数据更新逻辑批量删除批量删除和单条删除一样也属于危险操作。所以确认框仍然放在src/views/TasksView.vue而不是塞进 composable。这是因为确认框本质上是页面交互决策用户体验控制危险行为兜底不是纯数据处理。这一点你要牢牢记住确认框通常是页面层职责不是数据层职责。为什么“本页全选”比看起来更复杂很多初学者会觉得“不就是点一下全选吗很简单啊。”但真正落地时至少要处理这些情况当前页 4 条任务一条都没选当前页 4 条任务只选了 1 条当前页 4 条任务4 条全选当前页没任务选中跨页任务后再切分页删除任务后某些已选 id 已经失效所以你才会看到我们新增了selectedCurrentPageTaskCountisCurrentPageFullySelectedisCurrentPagePartiallySelected监听任务 id 变化并自动清理失效选择这就是复杂页面开发的真实样子不是“写一个按钮”而是“定义一整套稳定规则”。这节课的关键设计点1. 选择状态只存 id不存整条对象我们存的是constselectedTaskIdsrefnumber[]([])而不是直接存constselectedTasksrefTaskItem[]([])为什么因为存 id 更稳定不容易和最新任务对象脱节更新任务内容时不需要同步改两份对象删除任务时更容易清理真正要拿到完整任务对象时再通过computed推导selectedTasks这是一种非常常见的工程化写法。2. 批量完成只更新真正需要变更的项如果某些任务本来就已经是“已完成”那就没必要再重复更新。所以我们做了过滤只处理status ! 已完成的任务这样做的好处是逻辑更准确测试更容易写清楚用户提示更符合真实结果3. 批量操作后清空选择这节课里我们在批量完成和批量删除之后都做了clearTaskSelection()为什么这样设计因为对于初学者和这个教学项目来说这个策略最稳定用户不会误以为旧选择还有效页面更容易回到“干净状态”批量操作的前后状态边界更清楚在真实项目里也有团队会选择“操作后保留勾选”但那会带来更多交互细节。4. 如果正在编辑的任务被批量操作命中就关闭编辑弹窗这是这节课里一个很容易被忽略但非常像真实项目的问题。想象一下你正在编辑任务 A同时又把任务 A 勾上了然后执行批量完成或批量删除如果不处理弹窗里就可能还是旧数据。所以我们新增了一个辅助函数closeEditDialogIfNeeded它的作用是只要当前编辑项包含在本次批量操作里就主动关闭编辑弹窗并清空当前编辑目标这就是“页面状态协调”的典型案例。这节课改了哪些文件核心逻辑src/composables/useTasksPage.ts这里新增了选择状态本页全选逻辑批量完成逻辑批量删除逻辑失效选中项清理表格组件src/components/tasks/TaskTable.vue这里新增了选择列表头全选框行复选框相关事件抛出批量操作栏src/components/tasks/TaskBatchActionsBar.vue这是本课新增组件专门用于展示选择摘要提供清空/批量完成/批量删除按钮页面层协调src/views/TasksView.vue这里新增了批量操作栏渲染批量完成提示批量删除确认框批量删除成功/失败反馈页面头部说明src/components/tasks/TaskPageHeader.vue这里只是同步更新了说明文案让它和当前能力保持一致。测试src/composables/__tests__/useTasksPage.spec.tse2e/app.spec.ts这节课新增测试重点验证单条勾选本页全选半选状态批量完成批量删除编辑弹窗与批量操作之间的联动通过这节课你应该真正学会什么如果你只会“把功能写出来”那还不够。这节课你更应该学会下面这些思路页面复杂度上升时要优先考虑“状态放哪里”一组数据的操作通常都要先有“一组选中目标”ref保存原始状态computed负责推导派生状态展示组件尽量少管状态更多通过 props emit 配合页面层危险操作确认通常放在页面层不要轻易塞进 composable批量操作一定要考虑和“编辑中”“分页中”“筛选中”这些状态的关系如果这些思路你吃透了你离“会写页面”就不是初级水平了。你现在可以自己动手练什么建议你自己继续做 3 个小练习给批量操作再加一个“批量改为待评审”让批量操作栏显示“跨页共选中多少条”当切换筛选条件时尝试决定“是否保留隐藏任务的选择状态”第三个练习尤其值得你想。因为它没有唯一标准答案而是真实项目里经常要做的产品决策题。

相关文章:

第 17 课:任务选择与批量操作

第 17 课:任务选择与批量操作 这一课,我们继续把任务页做得更像真实后台系统。 上一课我们已经完成了: 单条任务删除危险操作确认框局部更新和局部删除 这一课继续升级,加入两个在真实项目里非常常见的能力: 勾选多条任…...

2026届必备的降AI率工具实测分析

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 伴随人工智能辅助写作越发普遍的情形下,切实减少文本的机器生成迹象变成内容创作…...

深入RK3588 ISP调试:用RKISP_Tuner在线抓Raw图与RTSP推流的实战技巧

深入RK3588 ISP调试:用RKISP_Tuner在线抓Raw图与RTSP推流的实战技巧 在嵌入式视觉系统的开发中,图像信号处理(ISP)调试是决定最终成像质量的关键环节。RK3588作为瑞芯微旗舰级芯片,其强大的ISP性能为开发者提供了广阔的…...

springboot私家车位共享系统小程序(文档+源码)_kaic

第5章 系统实现 5.1管理员功能模块 管理员登录,管理员通过输入用户名,密码,验证码等信息进入私家车位共享系统,如图5-1所示。 图5-1管理员登录界面图 管理员登录进入私家车位共享系统可以查看首页、轮播图、公告、资源管理&#…...

毕业答辩PPT制作:10款工具对比,助你轻松通过答辩

毕业答辩PPT制作是每位毕业生必须面对的挑战。你是否担心PPT设计不够专业、内容结构不清晰,或者时间紧迫无法高效完成?本文将围绕“毕业答辩PPT制作”这一核心关键词,为你推荐10款实用工具,包括第一款AIPPT,并提供免费…...

SPL06-001 气压计:从寄存器配置到数据校准的嵌入式实践

1. SPL06-001气压计基础与嵌入式应用场景 SPL06-001是Infineon推出的一款高精度数字气压传感器,采用MEMS技术实现压力测量。在嵌入式系统中,它常被用于无人机高度控制、气象站数据采集、室内导航等场景。我第一次接触这个传感器是在开发一个户外气象监测…...

KITTI数据集改造实战:用rosbag_filter_gui和merge_bags.py打造你的专属100Hz IMU融合数据集

KITTI数据集深度定制:构建100Hz IMU融合数据集的完整实战指南 在自动驾驶和机器人定位领域,KITTI数据集一直是算法验证的黄金标准。但当我们试图评估基于滤波的多传感器融合算法时,标准数据集中的10Hz IMU数据往往成为性能瓶颈。本文将带你从…...

热点文章_具身智能量产元年开启5亿订单人形机器人商业化飞轮启动开发者如何抓住红利_20260415_003

具身智能量产元年开启:5亿订单引爆人形机器人商业化飞轮,开发者如何抓住这波红利摘要:2026年被业界公认为"具身智能量产元年"。随着宇树科技冲刺科创板、智平方斩获5亿元全球最大单一订单、人形机器人进入规模化部署阶段&#xff0…...

从MATLAB到Tecplot:ASCII格式PLT文件的结构化数据转换实战

1. Tecplot ASCII格式PLT文件基础解析 第一次接触Tecplot的PLT文件格式时,我被它灵活的ASCII结构深深吸引。与二进制格式相比,ASCII格式虽然读取速度稍慢,但它的可读性和可调试性为工程师和科研人员提供了极大的便利。记得我刚开始处理CFD数据…...

OpenMV硬件魔改指南:如何给H743开发板添加自定义串口和SD卡检测

OpenMV H743硬件魔改实战:自定义串口与SD卡检测的深度优化 当标准OpenMV开发板的功能无法满足你的项目需求时,硬件层面的定制化改造就成为必经之路。本文将带你深入H743开发板的硬件适配层,通过修改底层配置文件实现串口扩展和SD卡检测优化&a…...

从手机导航到厘米级RTK:一文搞懂GNSS三大观测量(伪距、载波相位、多普勒)到底怎么用

从手机导航到厘米级RTK:GNSS三大观测量的技术跃迁与应用革命 当我们打开手机地图导航时,很少会思考那个蓝色定位点背后的技术奥秘。事实上,从日常导航到精准农业,从无人机测绘到自动驾驶,全球导航卫星系统(GNSS)技术的…...

大语言模型架构演进:从BERT到GPT再到Mamba的正确打开方式

先说结论大模型架构的演进史,本质上是一部"如何更高效承载智能"的优化史。从BERT的双向理解,到GPT的单向生成,再到Mamba的线性复杂度——每一代架构都在解决上一代的瓶颈。这个东西是什么想象一下,你要处理一段文字。BE…...

【AI Agent 从入门到精通】第六章:多智能体(Multi-Agent)系统架构详解:从双 Agent 协作到大型多 Agent 系统

📌 前置说明:本系列共 8 章,建议按顺序阅读。 📖 系列导航: 第一章:AI Agent 是什么?一文讲清楚核心概念与架构 第二章:AI Agent 的技术原理:LLM + 规划 + 记忆 + 工具 第三章:主流 AI Agent 框架对比:LangChain、AutoGPT、AutoGen、LlamaIndex 第四章:动手实现你…...

别只点灯了!用STM32的USB功能做个HID设备,实战项目带你理解USB协议

从零构建STM32 USB HID设备:以游戏手柄为例深入解析协议本质 当开发者第一次接触USB协议时,往往会被各种描述符、端点配置和枚举流程搞得晕头转向。市面上大多数教程只告诉你"怎么做",却很少解释"为什么这么做"。本文将打…...

51单片机蓝牙循迹小车:从模块集成到智能控制的实践解析

1. 项目概述与核心功能 这个小项目特别适合刚接触嵌入式开发的朋友练手。想象一下,用手机蓝牙遥控一辆能自动沿着黑线跑的小车,是不是挺有意思的?我去年带学生做这个项目时,发现它完美融合了硬件搭建和软件编程的乐趣。 核心功能其…...

Go语言怎么做指标监控_Go语言Metrics指标监控教程【经典】

必须显式调用 prometheus.MustRegister() 且仅一次,否则指标未注册导致 /metrics 为空或 404;自定义 Registry 需配 promhttp.HandlerFor(reg, ...),注册须在 ListenAndServe 前完成。用 prometheus/client_golang 暴露指标是 Go 服务监控的事…...

Smart PLC与Wincc通过Simatic NET建立OPC通讯(1)

1. 环境准备与软件安装 在开始配置Smart PLC与WinCC的OPC通讯之前,我们需要先准备好必要的硬件和软件环境。硬件方面,你需要一台S7-200 SMART PLC和一台带有集成以太网卡的PC机。软件方面则需要安装以下组件: STEP 7-Micro/WIN SMART V2.1&am…...

CSS如何引入媒体查询专用样式_利用media属性实现响应式加载

link的media属性仅控制CSS文件的加载时机&#xff0c;不决定样式生效条件&#xff1b;真正控制样式生效的是CSS内部的media规则&#xff0c;二者逻辑独立&#xff0c;不可混用。link标签的media属性只控制加载时机&#xff0c;不控制样式生效条件很多人以为给 <link> 加上…...

FreeRTOS实战:用互斥量和信号量搞定临界区,别再只会关中断了

FreeRTOS实战&#xff1a;互斥量与信号量的临界区保护策略精解 在嵌入式实时系统中&#xff0c;共享资源的保护如同交通枢纽的调度——一个微小的冲突可能导致整个系统瘫痪。我曾亲眼见证过一个工业传感器项目因为全局变量竞争导致数据错乱&#xff0c;最终引发产线停机。这让我…...

SQL如何统计分组内满足条件的唯一项_COUNT与DISTINCT

最稳妥的做法是COUNT(DISTINCT CASE WHEN ... THEN x END)。它在聚合内部完成条件过滤、去重和计数&#xff0c;兼容主流数据库&#xff0c;避免WHERE提前删行导致分组数据丢失或子查询逻辑错误。GROUP BY 里怎么数“满足条件的去重值”直接说结论&#xff1a;COUNT(DISTINCT C…...

考研复习 Day13| 数据结构与算法--线性表

一、线性表的定义和基本操作1.1 线性表的定义线性表&#xff1a;由 n(n≥0) 个相同数据类型的元素组成的有限序列。表示形式&#xff1a;L (a₁, a₂, , aᵢ, aᵢ₊₁, , aₙ)术语说明n表长&#xff1b;n0 时为空表a₁表头元素&#xff08;唯一的“第一个”元素&#xff09;aₙ…...

从播放到管理:用Vue3 + Pinia打造一个‘不打架’的多音频播放页(附完整代码)

构建互斥音频播放系统&#xff1a;Vue3与Pinia的实战解决方案 在语言学习平台、有声书应用或产品演示页面中&#xff0c;多音频交互是常见需求。当用户点击播放A音频时&#xff0c;B音频需要自动暂停——这种看似简单的逻辑背后&#xff0c;隐藏着状态同步、事件通信和性能优化…...

从零开始:在Android Studio中高效配置与调试AOSP源码

1. 为什么要在Android Studio中配置AOSP源码 第一次接触AOSP源码的开发者可能会有疑问&#xff1a;为什么非要把这么庞大的代码导入IDE&#xff1f;用文本编辑器查看不行吗&#xff1f;这个问题我也曾经思考过&#xff0c;直到真正尝试在Android Studio中调试过源码后&#xff…...

Gitee:AI赋能的国产研发协作平台如何重塑企业数字化进程

在数字化转型成为企业核心战略的当下&#xff0c;项目管理软件已经从简单的任务追踪工具进化为驱动研发效能提升的智能中枢。作为国内领先的代码托管与研发协作平台&#xff0c;Gitee&#xff08;码云&#xff09;凭借其全栈式解决方案与AI深度融合能力&#xff0c;正重新定义项…...

从焊接角度谈芯片封装:SOP/SOIC/MSOP的工艺要点与常见问题解决

从焊接角度谈芯片封装&#xff1a;SOP/SOIC/MSOP的工艺要点与常见问题解决 在电子制造领域&#xff0c;芯片封装的选择与焊接工艺直接影响着产品的可靠性和性能表现。SOP、SOIC和MSOP作为表面贴装技术(SMT)中最常见的封装类型&#xff0c;其焊接质量往往决定了电路板的良品率。…...

提升树(Boosting Tree)实战:从原理到Python实现

1. 提升树算法入门&#xff1a;从决策树到集成学习 提升树(Boosting Tree)是机器学习中一种强大的集成学习方法&#xff0c;它通过组合多个弱学习器&#xff08;通常是决策树&#xff09;来构建一个强学习器。我第一次接触这个概念是在解决一个房价预测问题时&#xff0c;当时单…...

从“惯性思维”到“规则驱动”:一次微信小程序修复引发的 AI 编程范式思考

最近&#xff0c;我在 Qoder&#xff08;我们的 AI 编程助手&#xff09;身上经历了一次深刻的“复盘”。这源于一个看似简单的微信小程序开发任务——自定义导航栏在刘海屏上的适配&#xff0c;&#xff08;我之前项目&#xff0c;qoder能很好的完成任务&#xff0c;但这次却是…...

不止是交换机监控:手把手教你用CactiEZ同时管好Windows和Linux服务器

异构IT环境监控实战&#xff1a;用CactiEZ统一管理Windows与Linux服务器 混合IT环境下的监控一直是运维人员的痛点。当你的网络里同时存在Cisco交换机、Windows Server和Ubuntu Linux服务器时&#xff0c;能否用一个工具实现统一监控&#xff1f;CactiEZ给出了肯定答案。这个基…...

告别网络卡顿!用国内镜像源+一键脚本5分钟搞定ROS2(Foxy/Humble/Jazzy)

5分钟极速部署ROS2&#xff1a;国内镜像源与智能脚本实战指南 为什么你的ROS2安装总是失败&#xff1f; 每次看到终端里卡在99%的进度条或是红色的GPG错误提示&#xff0c;是不是恨不得砸键盘&#xff1f;作为国内开发者&#xff0c;我们早已习惯了与境外服务器斗智斗勇的日常。…...

Java 面试手撕排序封神版!八大排序算法(快排 / 堆排 / 归并)手敲无 bug,面试直接默写

面试手撕排序整理完整版 面试中常考的手撕排序算法整理&#xff0c;可以直接照抄&#xff0c;包含 快速排序归并排序堆排序希尔排序直接插入排序选择排序计数排序冒泡排序 快速排序 丐版实现 public static void quickSort(ArrayList<Integer> arr, int begin, int end){…...