想要使用watch监听需要引入watch:
import {watch} from "vue";
监听某一个变量(浅层监听):
watch(变量名, (newValue, oldValue)=>{...})
我们监听变量num,通过输入input去改变num的值:
data:image/s3,"s3://crabby-images/d317d/d317d8a06916bdda2c14fa162303bd6b735130cc" alt=""
data:image/s3,"s3://crabby-images/91d97/91d97c72e62c4bded72d28c0fc8c1ad82b4be885" alt=""
监听对象中的某一个属性(深度监听):
watch(()=>变量名.value.属性名, (newValue, oldValue)=>{...})
data:image/s3,"s3://crabby-images/9c1d1/9c1d1be25a5ef39adc0ea8e03d2d2e7ead70ebfc" alt=""
data:image/s3,"s3://crabby-images/d689d/d689d5fd97f115120e887df81399663b467756be" alt=""
如果我们想要对该对象的所有属性都进行深度监听,则使用如下写法:
watch(变量名, (newValue, oldValue)=>{...}, {deep:true})
我们使用如下写法以后修改person中的所有属性都会触发watch:
data:image/s3,"s3://crabby-images/e625a/e625ab42acc31899df33d856ea2a92379664a07c" alt=""
注意:开启全属性深度监听会在一定程度上降低代码的性能
程序启动时立即进行一次监听:
watch(变量名, (newValue, oldValue)=>{...}, {deep:true, immediate:true})