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

Vue3中的computed 与 watch 的区别

Vue3中的computed 与 watch 的区别当你想要合成一个新数据用来显示时选computed。当你想要在数据变化时搞点事情调接口、存本地、操作 DOM选watch。computed计算属性computed主要用于数据的衍生与转换。它基于现有的响应式数据计算出一个新值并且会自动缓存计算结果。只有当它依赖的数据源发生变化时才会重新计算。// 写法 1函数形式最常用只读computed:{计算属性名(){// 依赖 this.xxx 数据return计算结果;}}// 写法 2对象形式可读可写computed:{计算属性名:{get(){return计算结果;},set(val){// 当你尝试修改这个计算属性时触发}}}应用场景购物车总价templatedivh2购物车/h2ulliv-for(item, index) in list:keyindex{{ item.name }} - {{ item.price }} xbuttonclickitem.count 1 ? item.count-- : -/button{{ item.count }}buttonclickitem.count/button/li/ul!-- 这里直接使用计算属性 --p总价{{ totalPrice }}/p/div/templatescriptexportdefault{data(){return{list:[{name:苹果,price:10,count:2},{name:香蕉,price:5,count:3}]};},computed:{// 只要 list 里任何商品的 price 或 count 变了totalPrice 自动更新totalPrice(){console.log(computed 重新计算了);// 验证缓存机制returnthis.list.reduce((sum,item)sumitem.price*item.count,0);}}};/script为什么用 computed 而不用 methods如果你在 methods 里定义一个getTotalPrice()函数虽然也能算出结果但computed有缓存。在上面的例子中如果你在页面多处调用totalPricecomputed 只会计算一次而 methods 每调用一次就会执行一次函数性能更低。watch侦听器watch主要用于观察某个数据的变化并执行特定的副作用。它关注的是 “数据变了之后要做什么”而不是为了得到一个返回值。这里的 “副作用” 通常指异步请求、DOM 操作、数据持久化等。watch:{// 写法 1简单监听数据名(newVal,oldVal){// newVal 是新值oldVal 是旧值// 执行逻辑...},// 写法 2对象形式开启深度监听、立即执行数据名:{handler(newVal,oldVal){// 逻辑...},deep:true,// 深度监听如果监听的是对象内部属性变化也能触发immediate:true// 立即执行页面加载完就先执行一次 handler}}搜索框防抖当用户输入停止后延迟 500ms 再发送请求。templatedivh2搜索电影/h2inputtypetextv-modelsearchTextplaceholder请输入关键词.../pv-ifloading搜索中.../pulv-elseliv-formovie in movies:keymovie.id{{ movie.title }}/li/ul/div/templatescriptexportdefault{data(){return{searchText:,movies:[],loading:false,timer:null};},watch:{// 监听 searchText 的变化searchText(newVal){// 1. 清除上一次的定时器if(this.timer)clearTimeout(this.timer);// 2. 如果输入为空清空列表直接返回if(!newVal){this.movies[];return;}this.loadingtrue;// 3. 设置新的定时器防抖核心this.timersetTimeout((){this.fetchMovies(newVal);},500);}},methods:{fetchMovies(keyword){// 模拟 API 请求console.log(发送请求关键词${keyword});setTimeout((){this.movies[{id:1,title:keyword之传奇诞生},{id:2,title:keyword之王者归来}];this.loadingfalse;},1000);}}};/script为什么这里必须用 watch因为我们需要在数据变化后执行 “延迟” 和 “发请求” 这些异步操作computed内部必须是同步的 return无法处理这种场景。维度computedwatch返回值必须有 return不需要 return缓存有缓存性能优先无缓存变了就执行异步不支持异步支持异步操作场景多对一一个值由多个值计算而来 (ABC)一对多一个值变化影响多个逻辑 (A 变了触发 B、C、D)

相关文章:

Vue3中的computed 与 watch 的区别

Vue3中的computed 与 watch 的区别 当你想要合成一个新数据用来显示时,选 computed。当你想要在数据变化时搞点事情(调接口、存本地、操作 DOM),选 watch。 computed:计算属性 computed 主要用于数据的衍生与转换。它基…...

IPv4 与 IPv6 的核心区别

IPv4与IPv6的区别 一句话总结:IPv4 地址不够用、配置麻烦、安全性弱;IPv6 地址极多、自动配置、性能更强,是下一代互联网协议。 一、核心区别详情 1. 地址长度与数量IPv4:32位,地址总数约 42.9亿,随着互联网…...

兼容性测试覆盖多平台与多版本

兼容性测试:跨越平台与版本的品质保障 在数字化时代,软件和应用程序需要在多种操作系统、设备和版本上稳定运行。兼容性测试作为质量保障的关键环节,确保产品在不同环境下表现一致。随着用户终端多样化,覆盖多平台与多版本的测试…...

ASyncTicker:嵌入式非中断周期任务调度器

1. ASyncTicker:面向嵌入式实时系统的非中断式周期任务调度器在嵌入式系统开发中,周期性任务调度是高频刚需——LED呼吸灯、传感器采样、通信心跳包、PID控制循环、状态机轮询等场景均依赖稳定、可预测的定时触发机制。传统方案多基于硬件定时器中断服务…...

软件可解释性的决策原因与逻辑展示

## 软件可解释性:让算法决策不再神秘 在人工智能和机器学习快速发展的今天,越来越多的决策由软件系统自动完成。许多复杂的算法(如深度神经网络)往往被视为“黑箱”,其决策过程难以理解。这种不透明性可能导致用户对系…...

拆穿名词诈骗!用大白话理解晦涩难懂的AI概念谒

1. 架构背景与演进动力 1.1 从单体到碎片化:.NET 的开源征程 在.NET Framework 时代,构建系统主要围绕 Windows 操作系统紧密集成,采用传统的封闭式开发模式。然而,随着.NET Core 的推出,微软开启了彻底的开源与跨平台…...

再次革新 .NET 的构建和发布方式(一)帕

本文能帮你解决什么? 1. 搞懂FastAPI异步(async/await)到底在什么场景下能真正提升性能。 2. 掌握在FastAPI中正确使用多线程处理CPU密集型任务的方法。 3. 避开常见的坑(比如阻塞操作、数据库连接池耗尽、GIL限制)。 …...

GoCodingInMyWay淖

一、什么是 Q 饱和运算? 1. 核心痛点:普通运算的 “数值回绕” 普通算术运算(如 ADD/SUB)溢出时,数值会按补码规则 “回绕”,导致结果完全错误: 示例:int8_t 类型最大值 127 1 → 结…...

YOLO-Master 与 YOLO 开始朴

AI Agent 时代的沙箱需求 从 Copilot 到 Agent:执行能力的质变 在生成式 AI 的早期阶段,应用主要以“Copilot”形式存在,AI 仅作为辅助生成建议。然而,随着 AutoGPT、BabyAGI 以及 OpenAI Code Interpreter(现为 Advan…...

微服务可观测性建设

微服务可观测性建设:打造高效运维的基石 在数字化转型的浪潮中,微服务架构凭借其灵活性和可扩展性成为企业技术演进的主流选择。随着服务数量的激增和分布式系统的复杂性提升,传统的监控手段已难以满足运维需求。微服务可观测性建设应运而生…...

使用 Alertmanager 配置智能告警

在微服务与云原生架构盛行的当下,系统监控与告警管理成为保障业务稳定性的关键环节。Alertmanager作为Prometheus生态中的核心告警组件,通过灵活的配置和智能路由策略,能够将海量告警转化为精准的行动指令,帮助运维团队快速响应问…...

RGBW色彩转换器:嵌入式系统高保真白光增强方案

1. RGBW色彩转换器技术解析:面向嵌入式显示系统的高保真白光增强方案1.1 工程背景与设计动因在LED显示与智能照明嵌入式系统中,RGB三色LED驱动已成主流,但其在高亮度白光输出场景下存在固有缺陷:当需呈现高亮度中性白(…...

CopyOnWriteArrayList 实现原理

什么是CopyOnWriteArrayList?CopyOnWriteArrayList 是 Java 并发包 (java.util.concurrent) 中一个非常独特且重要的线程安全集合。与 Collections.synchronizedList 不同,CopyOnWriteArrayList 不依赖外部同步,而是通过内部机制实现并发控制…...

ADS1220_WE库详解:工业级24位ADC驱动与高精度传感器采集实现

1. ADS1220_WE 库深度技术解析:面向工业级高精度采集的 24 位四通道 ADC 驱动实现1.1 芯片级定位与工程价值ADS1220 是德州仪器(TI)推出的低功耗、高精度、24 位 Δ-Σ 型模数转换器,专为工业传感器信号调理场景设计。其核心价值不…...

VL6180X_WE中断驱动库:工业级ToF传感器低功耗实时方案

1. VL6180X_WE 库概述:面向工业级应用的增强型 ToF 传感器驱动 VL6180X_WE 是一款专为意法半导体(STMicroelectronics)VL6180X 飞行时间(Time-of-Flight, ToF)传感器设计的嵌入式 C 驱动库。该库并非从零构建&#xf…...

Adafruit ZeroI2S:面向Cortex-M0+/M4的零拷贝I2S音频驱动

1. 项目概述Adafruit ZeroI2S 是专为基于 SAMD21(Arduino Zero / Adafruit Metro M0 Express / Feather M0 Express)与 SAMD51(Adafruit Metro M4 Express / Feather M4 Express / ItsyBitsy M4 Express)微控制器的 Arduino 兼容开…...

Linux I/O 演进史:从管道到零拷贝,一篇串起个服务端核心原语撑

前言 在使用 kubectl get $KIND -o yaml 查看 k8s 资源时,输出结果中包含大量由集群自动生成的元数据(如 managedFields、resourceVersion、uid 等)。这些信息在实际复用 yaml 清单时需要手动清理,增加了额外的工作量。 使用 kube…...

-:RAG 入门-向量存储与企业级向量数据库 milvus匾

起因是我想在搞一些操作windows进程的事情时,老是需要右键以管理员身份运行,感觉很麻烦。就研究了一下怎么提权,顺手瞄了一眼Windows下用户态权限分配,然后也是感谢《深入解析Windows操作系统》这本书给我偷令牌的灵感吧&#xff…...

代码规范与团队协作效率

代码规范与团队协作效率:提升开发质量的关键 在软件开发中,代码规范与团队协作效率是决定项目成败的重要因素。统一的代码规范能减少维护成本,提高可读性,而高效的团队协作则能加速交付周期,降低沟通成本。尤其在多人…...

路由权限管理

路由权限管理:构建安全高效的前端架构 在现代前端开发中,路由权限管理是保障系统安全性和用户体验的核心环节。随着单页应用(SPA)的普及,前端路由的复杂性逐渐增加,如何动态控制用户访问权限成为开发者必须…...

使用 Python 设置 Excel 表格的行高与列宽

在技术领域,我们常常被那些闪耀的、可见的成果所吸引。今天,这个焦点无疑是大语言模型技术。它们的流畅对话、惊人的创造力,让我们得以一窥未来的轮廓。然而,作为在企业一线构建、部署和维护复杂系统的实践者,我们深知…...

计算机毕业设计:Python城市空气质量智能监测与预测平台 Django框架 可视化 数据分析 Prophet时间序列 大数据 大模型 深度学习(建议收藏)✅

博主介绍:✌全网粉丝10W,前互联网大厂软件研发、集结硕博英豪成立工作室。专注于计算机相关专业项目实战6年之久,选择我们就是选择放心、选择安心毕业✌ > 🍅想要获取完整文章或者源码,或者代做,拉到文章底部即可与…...

Pharma RAG:企业知识库的架构革命

一、为什么制药行业的知识库问题比你想的严重 一名医学写作(Medical Writer)在准备 CTD 5.3.5.1(临床研究报告摘要)时,需要交叉引用: 3 份 Phase III CSR(临床研究报告),每份 800–2000 页 协议书修正案 5 个版本 统计分析报告(SAP)+ 列表表格(TLF)共 1200 张 竞…...

AI Agent Pharma:从 Copilot 到 Autonomous Pharma

当药物研发遇上 AI Agent,不是锦上添花,是游戏规则的重写。本文拆解架构、给出可跑的代码、聊聊那些 PPT 不会告诉你的坑。在这里插入图片描述 一、我为什么在写这篇文章 大概是 2023 年末,我们团队拿到了一个任务:帮某中型药企的研发部门"引入 AI"。预算不小,…...

CKKS 同态加密数学基础推导信

背景 StreamJsonRpc 是微软官方维护的用于 .NET 和 TypeScript 的 JSON-RPC 通信库,以其强大的类型安全、自动代理生成和成熟的异常处理机制著称。在 HagiCode 项目中,为了通过 ACP (Agent Communication Protocol) 与外部 AI 工具(如 iflow …...

从识别到创作:Hunyuan OCR与Z-Image-Turbo在NPU平台上的协同进化,重塑AI视觉工作流

1. 当OCR遇上图像生成:Hunyuan与Z-Image-Turbo的化学反应 第一次看到Hunyuan OCR和Z-Image-Turbo在同一个NPU平台上跑起来时,我正忙着处理一堆杂乱的产品说明书。这些文档有扫描件、手机拍摄的模糊照片,甚至还有手写批注的PDF。传统方案需要…...

Linpeas使用教程

在Kali Linux的权限提升工具库中,Linpeas(Linux Privilege Escalation Awesome Script)是一款专注于Linux系统本地权限提升的自动化脚本工具,隶属于“PEASS(Privilege Escalation Awesome Scripts SUITE)”…...

思博伦TCL并发测试避坑指南:HTTP/1.1配置与端口关联的最佳实践

思博伦TCL并发测试避坑指南:HTTP/1.1配置与端口关联的最佳实践 在性能测试领域,思博伦(Spirent)的TCL测试工具因其强大的功能和灵活性而备受推崇。然而,正是这种灵活性也带来了配置上的复杂性,特别是在HTTP…...

PEASS使用教程

在Kali Linux的权限提升工具生态中,PEASS(Privilege Escalation Awesome Scripts SUITE,权限提升优秀脚本套件)是一款覆盖Linux与Windows双平台的自动化权限提升扫描工具集。它通过整合Linpeas(Linux平台)与…...

winpeas使用教程

winpeas是PEASS(Privilege Escalation Awesome Scripts SUITE,权限提升优秀脚本套件)中的Windows平台专用模块,全称为Windows Privilege Escalation Awesome Script。它是一款专为Windows系统设计的自动化权限提升扫描工具&#x…...