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

vue 监听 取消监听

vue 的 watch 除了可以使用声明式的配置项以外,还可以通过命令式 this.$watch 方法。
如下是我们比较少用的命令式(想要初始只监听一次,必须命令式写法):

监听只运行一次
声明式

export default{data: {showType: false},watch: {showType(newValue, oldValue) {console.log(newValue)}}
}

命令式
监听一次 必须是命令写法,
命令式好处是,可以得到一个取消监听的函数,在需要时取消监听,比如你想要只监听一次,可以像下面使用:

export default {data: {showType: false},mounted() {this.$watch('showType', function(newValue, oldValue){console.log(newValue);});},
}

深度监听
监听对象重某一个属性

data() {return {numbers: {a: 1,b: 1}}}watch: {'numbers.a': {handler(newValue, oldValue) {console.log(newValue, oldValue)console.log('numbers正在被侦听')},deep: true,  // 是否深度监听immediate: true  // 页面加载立即执行}
-------------------------------另一种写法-----------------------------'dict.a'(newValue, oldValue){console.log(newValue, oldValue)console.log('numbers正在被侦听')},
}
``
**监听对象中的每一个属性**
data() {return {numbers: {a: 1,b: 1}}
},

watch: {
numbers: {
handler(newValue, oldValue) {
console.log(newValue, oldValue)
console.log(‘numbers正在被侦听’)
},
deep: true
immediate: true
},
}
created() {
setTimeout(() => {
this.numbers.a = 5
this.numbers.b = 50
}, 2000)
}


http://www.lryc.cn/news/31124.html

相关文章:

  • 0103深度优先搜索和单点连通-无向图-数据结构和算法(Java)
  • 进销存管理系统
  • Sonar:VSCode配置SonarLint/SonarLint连接SonarQube
  • 陀螺仪小车(Forerake-Car)
  • Leetcode Day5 含有重复元素集合的组合+
  • Mac Book pro(M1)使用总结
  • QML集成JavaScript
  • 学习周报3.5
  • java基础学习篇
  • Go 语言基础语法及应用实践
  • C语言自定义类型---进阶
  • 85.链表总结
  • 【博学谷学习记录】超强总结,用心分享|狂野大数据课程【DataFrame的相关API】的总结分析
  • 粒子群优化最小二乘支持向量机SVM回归分析,pso-lssvm回归预测
  • lavis多模态开源框架学习--安装
  • 【IDEA】如何在Tomcat上创建部署第一个Web项目?
  • 程序员画流程图的工具Draw.io
  • CAPL脚本DBLookup函数动态访问CAN 报文的属性
  • 2022年显卡性能跑分排名表
  • mx-font
  • 基于S32K148快速调试TJA1101
  • 万字长文详解webpack知识图谱
  • 模板测试(Stencil Test)
  • 【Go语言学习】安装与配置
  • HCIP-5OSPF区域类型学习笔记
  • C语言再学习第三章
  • 【aiy篇】小目标检测综述
  • 常用Linux命令的基本使用
  • 对跳表的深入理解
  • C++017-C++冒泡排序与插入排序