news 2026/4/18 11:07:37

this.$watch

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
this.$watch

watch 与 this.$watch 核心区别

watch(选项式)在组件初始化阶段(created前)就创建监听,若数据是异步请求的,初始化时监的是空值;this.watch可以等异步数据请求回来后再创建监听,避开无效空值监听。但this.watch需要手动销毁,一般在组件销毁前(beforeDestroy)执行;选项式watch由Vue自动创建+自动销毁,无需手动处理。二者其他功能和底层逻辑完全一致。

#1. 核心定位

二者都是Vue监听响应式数据变化的方式,底层逻辑、功能(深度监听/立即执行)完全一致,仅在监听创建时机、销毁方式上有区别,本质是「自动托管」和「手动控制」的差异。

2. 选项式 watch(直接写在配置里)

  • 创建时机:组件初始化阶段(created之前)自动创建,监听从组件诞生就生效;
  • 销毁方式:组件销毁时Vue自动销毁,无需手动操作,省心;
  • 适用场景:数据初始化就有值、不在意初始空值;或简单场景,不想写额外手动代码;
  • 关键特点:默认只监数据变化,初始空值不会触发回调,无额外副作用;仅开 immediate: true 时,才会触发初始空值的回调,需加非空判断。

3. this.$watch(手动调用方法)

  • 创建时机:手动调用时才创建,时机完全可控(可写在mounted/异步请求成功后);
  • 销毁方式:调用后返回销毁函数,需手动在 beforeDestroy 执行销毁,否则会内存泄漏;
  • 适用场景:异步请求数据的场景,可等数据拿到(有有效值)后再创建,彻底避开初始空值;
  • 关键特点:精准匹配数据有效时机,无需处理空值相关逻辑;想创建后立即执行回调,开 immediate: true 也只会触发有效值,不用加判断。

4. 开发选择原则(一句话记)

  • 数据早有值/不在意空值 → 用选项式watch(省心,自动托管);
  • 异步数据/想避开初始空值 → 用this.$watch(灵活,时机精准)。

5. 高频易错点

  • 选项式watch监初始空值默认不触发回调,不用额外写非空判断,只有开 immediate: true 才需要;
  • this.$watch创建时的当前值是「基准值」,不会触发回调,只有后续值变化才会触发;
  • this.$watch是手动创建一次,销毁即失效,想重新监听需再次调用方法。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 6:28:48

视觉VLA看不到的“那堵墙”,被发现了......

想象一下:在一个阳光充足的下午,机器人在打扫房间。在窗户边上的桌子,透明的玻璃水杯需要放回指定的位置,机器人走过去,面对强光直射和透明的物体,机器人只能无意义的重复抓取动作,仿佛面对一个…

作者头像 李华
网站建设 2026/4/18 6:28:24

贪心算法经典案例解析:找零与哈夫曼编码应用

贪心算法是一种在每一步选择中都采取当前最优解的算法策略。虽然它不能保证所有问题都得到全局最优解,但在某些特定问题上,贪心策略非常高效且能得到正确结果。本文将通过几个经典的实例,来具体说明贪心算法的实际应用和其背后的逻辑。 贪心…

作者头像 李华
网站建设 2026/4/18 6:25:30

突破规模极限:AI前沿五大颠覆性技术洞察

引言:超越更大模型 如果你仅通过头条新闻关注AI,故事似乎简单且重复:一个新模型在基准测试中胜出,宣称拥有更长的上下文窗口,并塞进了更多参数。但在这股蛮力进步的叙事之下,一种更奇特、更复杂的现实正从研…

作者头像 李华
网站建设 2026/4/17 13:36:10

AI在气候模型软件测试中的准确性验证:专业测试从业者指南

气候模型测试的AI转型 气候模型(如一般环流模型GCMs)是天气和气候预测的核心,但传统测试方法面临算力消耗大、长期预测不确定性高等挑战。AI技术的融入,如谷歌的NeuralGCM模型,通过结合机器学习与物理方法&#xff0c…

作者头像 李华
网站建设 2026/4/18 8:00:13

php JWT 使用全攻略(firebase/php-jwt 实践笔记)

一、前置准备 1. 安装库 使用 Composer 安装 firebase/php-jwt 是使用该库的前提。 composer require firebase/php-jwt 2. 核心类与方法 核心类:Firebase\JWT\JWT(所有操作围绕此类展开)核心静态方法: JWT::encode()&#xff1a…

作者头像 李华