vue2的watch详解。真的是服了这个watch有bug

在 Vue.js 2 中,watch 是一个用来观察和响应 Vue 实例数据变动的选项。它可以用来监听数据的变化并执行相应的逻辑,比如在数据变化时更新界面或者执行一些异步操作。

基本用法

监听单个数据源

最简单的用法是监听单个数据源(即一个数据属性)的变化:

new Vue({data: {message: 'Hello, Vue.js!'},watch: {message: function(newVal, oldVal) {console.log(`message 从 ${oldVal} 变为 ${newVal}`);}}
});
监听多个数据源

你也可以同时监听多个数据源,将 watch 中的键值对扩展为多个属性:

new Vue({data: {firstName: 'John',lastName: 'Doe',fullName: 'John Doe'},watch: {firstName: function(newVal, oldVal) {this.fullName = newVal + ' ' + this.lastName;},lastName: function(newVal, oldVal) {this.fullName = this.firstName + ' ' + newVal;}}
});

这时候打印的newval和oldval是不一样的。因为他是单个数据源。当我们监听对象里面的属性时就发现了不同了。

高级用法

深度监听对象或数组的变化

当需要监听对象或数组内部属性的变化时,可以设置 deep: true

new Vue({data: {user: {name: 'John',age: 30}},watch: {user: {handler: function(newVal, oldVal) {console.log('user 对象发生变化',newVal, oldVal);},deep: true}}
});

这时候打印的newVal, oldVal其实是一样的,而且必须加上deep:true。要不然即使对象里面属性改变handler函数也是不执行的。可以去掉试试。

使用 deep: true 可以深度遍历对象内部的属性,当任意属性发生变化时都会触发 watch 的处理函数。

娜娜娜娜,我们yao监听对象里的属性怎么办,只想其中的属性改变时执行某个方法怎么办,

see👇

 监听对象里的属性

new Vue({data: {user: {name: 'John',age: 30,type: 30,}},watch: {'user.type': {handler(newVal, oldVal) {// 打印旧值和新值console.log('旧值:', oldVal, '新值:', newVal);// 执行相关操作if (newVal !== oldVal) {// this.updateStyle();this.addMapServer(newVal);}},immediate: true // 立即执行一次监听函数}}
});

立即触发监听函数

可以通过设置 immediate: true 来立即触发监听函数,即在初始化时立即执行一次监听函数:

new Vue({data: {count: 0},watch: {count: {handler: function(newVal, oldVal) {console.log(`count 的值变为 ${newVal}`);},immediate: true}}
});
如果要监听对象里面多个属性变化

你可以使用计算属性来派生新的数据,然后通过 watch 特性来监听这个计算属性的变化。

computed: {
comSetView() {return `${this.option.lng},${this.option.lat},${this.option.height},${this.option.pitchRadiu}`;}
}watch: {comSetView: {deep: true,handler(){this.metSetView()}},
}

这样就不用一个一个属性的拆开写了

移除监听

如果需要在组件销毁时移除 watch,可以通过 vm.$watch 返回的函数来移除监听:

var unwatch = vm.$watch('expression', callback);// 在适当的时机移除监听
unwatch();

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

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

相关文章

观成科技:证券行业加密业务安全风险监测与防御技术研究

摘要:解决证券⾏业加密流量威胁问题、加密流量中的应⽤⻛险问题,对若⼲证券⾏业的实际流量内容进⾏调研分析, 分析了证券⾏业加密流量⾯临的合规性⻛险和加密协议及证书本⾝存在的⻛险、以及可能存在的外部加密流量威 胁,并提出防…

[JS面试题]面试官:实现一个调度器,最多只能同时有两个任务同时进行

[JS面试题]面试官:实现一个调度器,最多只能同时有两个任务同时进行 这个调度器的工作方式是,它会持续检查任务队列,并且每次最多启动两个任务。当一个任务完成(无论是成功还是失败)时,它会立即…

PHP 超级全局变量详解

在PHP编程中,超级全局变量(Super Global Variables)是一种特殊的变量,可以在脚本的任何地方访问,而不受作用域限制。它们被设计用于在不同的脚本文件、函数和类之间共享数据,是PHP语言中非常重要和实用的特…

Knife4j 2.2.X 版本 swagger彻底禁用

官方文档配置权限:https://doc.xiaominfo.com/v2/documentation/accessControl.html#_3-5-1-%E7%94%9F%E4%BA%A7%E7%8E%AF%E5%A2%83%E5%B1%8F%E8%94%BD%E8%B5%84%E6%BA%90 通常有时候我们碰到的问题如下: 在开发Knife4j功能时,同很多开发者经常讨论的问…

c语言预处理和可变参数的使用

概述 预处理名称意 义#define宏定义#undef撤销已定义过的宏名#include使编译程序将另一源文件嵌入到带有#include 的源文件中#if如果条件为真,则执行相应操作#elif如果前面条件为假,而该条件为真,则执行相应操作#else如果前面条件均为假&…

MySQL数据库简介和安装

文章目录 一、数据库原理目前情况数据库的发展史RDBMS关系型数据库关系型数据库理论 二、MySQL历史发展历程关系型数据库和非关系型数据库 三、安装mysql及优化yum安装编译安装mysql二进制安装优化操作 四、 安装mycli插件客户端工具 一、数据库原理 目前情况 我们正处于一个…

考研:数学一/二 和英语一/二 有什么区别

考研数学一/二 区别: 考试内容: 数学一:考查内容包括高等数学、线性代数、以及概率论与数理统计,覆盖的知识面较为全面,题目难度也相对较高。数学二:考试内容包含高等数学和线性代数,不包括概率…

聚观早报 | 真我GT6官宣;iQOO 13参数细节曝光

聚观早报每日整理最值得关注的行业重点事件,帮助大家及时了解最新行业动态,每日读报,就读聚观365资讯简报。 整理丨Cutie 6月26日消息 真我GT6官宣 iQOO 13参数细节曝光 苹果iPadOS 18 Beta 2更新 一加Ace 3 Pro散热细节曝光 亚马逊秘…

Redis-主从复制-配置主从关系

文章目录 1、修改配置文件中的 bind ,注释该配置,取消绑定仅主机登录2、修改protected-mode 为no,取消保护模式3、查看redis的进程状态4、配置6380是6379的从机5、配置6381是6379的从机6、查看主机 6379 的主从信息 1、修改配置文件中的 bind ,注释该配置,取消绑定仅主机登录 …

【MySQL】(基础篇十七) —— 存储过程

存储过程 本文将介绍什么是存储过程,为什么要使用存储过程以及如何使用存储过程,并且介绍创建和使用存储过程的基本语法。 MySQL的存储过程是预编译的SQL语句集合,它们作为一个可执行单元存储在数据库中。存储过程能够封装复杂的业务逻辑&a…

leetcode-19-回溯

引自代码随想录 [77]组合 给定两个整数 n 和 k,返回 1 ... n 中所有可能的 k 个数的组合。 示例: 输入: n 4, k 2 输出: [ [2,4], [3,4], [2,3], [1,2], [1,3], [1,4]] 1、大致逻辑 k为树的深度,到叶子节点的路径即为一个结果 开始索引保证不重复…

1.1章节print输出函数语法八种 使用和示例

1.打印变量和字符串 2-4.三种使用字符串格式化 5.输出ASCLL码的值和中文字符 6.打印到文件或其他对象(而不是控制台) 7.自定义分隔符、和换行符和结束符 8.连接符加号连接字符串 在Python中,print() 函数用于在控制台上输出信息。这是一个非常…

docker原理记录C-N-A

docker原理 容器技术的兴起源于 PaaS 技术的普及 Docker 项目通过“容器镜像”,解决了应用打包这个根本性难题容器本身没有价值,有价值的是“容器编排”Cgroups 和 Namespace Cgroups 技术是用来制造约束的主要手段,而Namespace 技术则是用…

CRM软件:如何提升团队的销售效率?

销售是企业的驱动力。如果没有一支强大的销售团队,企业很难在当今激烈的竞争中发展壮大并取得成功。为了确保成功,企业需要专注于提高销售效率。 但销售效率到底是什么?企业如何优化和衡量其成功与否?本文将详细解答这些问题。 …

兴趣爱好广泛的人,如何填报高考志愿选专业?

一般来说,高考填报志愿都要以自己的兴趣为基础。但是对于有一些比较优秀的同学来说,自己的兴趣可能是非常广,涉及到各个专业方方面面。有些同学琴棋书画样样精通,对于很多的专业,他们都充满了兴趣,而且兴趣…

Java-方法引用

方法引用概念 把已经有的方法拿过来用,当做函数式接口中抽象方法的方法体 前提条件 1、引用处必须是函数式接口 2、被引用的方法必须已经存在 3、被引用方法的形参和返回值 需要跟抽象方法保持一致 4、被引用方法的功能要满足当前需求 方法引用格式示例 方…

第四天 怎么又迟到了呀 哎啥时候来准时上个课呀

泛型编程 Traits实现,是什么 泛型编程(Generic Programming)是一种通过编写与特定类型无关的代码来实现代码复用和抽象的编程范式。 在C中,模板(Templates)是实现泛型编程的主要手段。 Traits&#xff0…

一文入门CMake

我们前几篇文章已经入门了gcc和Makefile,现在可以来玩玩CMake了。 CMake和Makefile是差不多的,基本上是可以相互替换使用的。CMAke可以生成Makefile,所以本质上我们还是用的Makefile,只不过用了CMake就不用再写Makefile了&#x…

【ajax实战05】文章封面发布

一&#xff1a;实现效果 二&#xff1a;实现步骤 1 准备标签结构和样式 html结构样式 <div class"cover"><label for"img">封面&#xff1a;</label><label for"img" class"place"></label><inpu…

2025秋招NLP算法面试真题目录

2025 秋招 NLP 算法面试真题专栏包含&#xff1a;预训练模型、文本表征、文本相似度、文本分类、多模态、知识蒸馏、词向量等内容&#xff0c;涵盖全面&#xff0c;实用性强。欢迎订阅&#xff0c;专栏将持续更新&#xff0c;助力您的秋招备战&#xff01; 深度学习自然语言处…