vue 监听 取消监听
创始人
2024-05-29 01:07:01
0

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)
}


相关内容

热门资讯

评书童林传250回的和300回... 评书童林传250回的和300回的有什么不一样?内容上是完全一样的,只是在剪辑时语速有所不同。 ...
为啥 有声小说凡人修仙传 和 ... 为啥 有声小说凡人修仙传 和 修真世界 很久都不更新了呢? 播音大灰狼去干吗了?凡人修仙传 和 修真...
月宫的主人不是嫦娥,你知道《封... 月宫的主人不是嫦娥,你知道《封神榜》中姜子牙封了谁吗?大家口中所说的嫦娥在历史上,其实并不是一个人,...
华软科技涨1.15%,成交额6... 7月1日,华软科技盘中上涨1.15%,截至09:57,报6.17元/股,成交6068.05万元,换手...
时间久了是不是真的会忘记? 时间久了是不是真的会忘记?如果那时是真的伤到了心,是不会忘记的,只会淡化,再久的时间想起来还是会有一...
菲沃泰涨1.21%,成交额66... 7月1日,菲沃泰盘中上涨1.21%,截至09:58,报16.76元/股,成交662.09万元,换手率...
党员总数超28.77万名 基层... 来源:本站原创  安庆市委组织部最新党内统计数据显示,截至2024年底,安庆市共有中国共产党党员28...
三棵树成立新材料科技子公司 转自:证券时报人民财讯7月1日电,企查查APP显示,近日,三棵树(海南)新材料科技有限公司成立,注册...
正海生物涨1.07%,成交额9... 7月1日,正海生物盘中上涨1.07%,截至09:43,报20.72元/股,成交936.02万元,换手...
奥联电子跌1.01%,成交额1... 7月1日,奥联电子(维权)盘中下跌1.01%,截至09:44,报15.69元/股,成交1018.39...