watch顾名思义,属于vue2.x版本中,监听和观察组件状态变化的钩子函数,常见的应用场景有监听路由变化,以及父组件传递给子组件的props数据的变化等
基本使用
在使用watch的时候,需要在data中生命一个状态,并添加到watch当中进行观察,当发生变化时,watch可以通过默认参数获取最新的值的变化
<li>name值:{{ name }}</li>
<li>{{ nameTip }}</li>
<li>通过异步操作获取的age:{{ age }}</li>
<li><button @click="getUser">修改名字</button></li>
let p1 = new Promise((resolve, reject) => {
resolve({ age: "14" });
});
data() {
return {
name: "zhangsan",
nameTip: "name未改变",
};
},
watch: {
name(newVal, oldVal) {
// watch可以监听一些状态发生更改的时候,做一些处理,修改状态,或者异步操作
this.nameTip = "name状态改变了";
this.getData();
},
},
methods: {
getData() {
setTimeout(() => {
this.getAge();
}, 1000);
},
getUser() {
this.name = "lisi";
},
getAge() {
p1.then((res) => {
console.log(res);
this.age = res.age;
});
},
},
当点击修改的时候,name的值会被修改为lisi,watch监听到name的修改之后,可以修改nameTip的文字,进行出发修改别的状态,
我们也可以通过newVal获取name的最新的值,或者oldVal的值进行一些对比和操作
使用promise和定时器模拟当状态变化的时候,请求后台数据并渲染,这是我们在开发过程中,对watch使用的一个比较典型的例子
www.iimedia.cn/tag/%E5%8C%… www.iimedia.cn/tag/%E4%B8%… www.iimedia.cn/tag/%E5%B9%… www.iimedia.cn/tag/%E6%B7%… www.iimedia.cn/tag/%E5%A4%… www.iimedia.cn/tag/%E6%9D%… www.iimedia.cn/tag/%E5%8D%… www.iimedia.cn/tag/%E6%B5%… www.iimedia.cn/tag/%E9%87%… www.iimedia.cn/tag/%E9%9D%… www.iimedia.cn/tag/%E5%A4%… www.iimedia.cn/tag/%E5%AE%… www.iimedia.cn/tag/%E5%8E%… www.iimedia.cn/tag/%E6%88%… www.iimedia.cn/tag/%E6%AD%… www.iimedia.cn/tag/%E5%93%… www.iimedia.cn/tag/%E6%B2%… www.iimedia.cn/tag/%E8%A5%… www.iimedia.cn/tag/%E9%95%… www.iimedia.cn/tag/%E9%95%… www.iimedia.cn/tag/%E7%A6%… www.iimedia.cn/tag/%E9%83%… www.iimedia.cn/tag/%E7%9F%… www.iimedia.cn/tag/%E8%8B%… www.iimedia.cn/tag/%E4%BD%… www.iimedia.cn/tag/%E4%B8%… www.iimedia.cn/tag/%E6%97%… www.iimedia.cn/tag/%E7%83%… www.iimedia.cn/tag/%E5%A4%… www.iimedia.cn/tag/%E5%90%… www.iimedia.cn/tag/%E5%8D%… www.iimedia.cn/tag/%E5%8D%… www.iimedia.cn/tag/%E6%98%… www.iimedia.cn/tag/%E6%B8%… www.iimedia.cn/tag/%E6%B7%… www.iimedia.cn/tag/%E5%94%… www.iimedia.cn/tag/%E4%B9%… www.iimedia.cn/tag/%E8%B4%… www.iimedia.cn/tag/%E6%B5%… www.iimedia.cn/tag/%E5%85%… www.iimedia.cn/tag/%E9%93%… www.iimedia.cn/tag/%E8%A5%… www.iimedia.cn/tag/%E5%91%… www.iimedia.cn/tag/%E6%B3%… www.iimedia.cn/tag/%E5%8C%… www.iimedia.cn/tag/%E5%8D%… www.iimedia.cn/tag/%E5%A4%… www.iimedia.cn/tag/%E5%BE%… www.iimedia.cn/tag/%E6%BD%… www.iimedia.cn/tag/%E5%B8%… www.iimedia.cn/tag/%E9%84%… www.iimedia.cn/tag/%E7%BB%… www.iimedia.cn/tag/%E6%B5%… www.iimedia.cn/tag/%E7%9B%… www.iimedia.cn/tag/%E9%82%… www.iimedia.cn/tag/%E4%B8%… www.iimedia.cn/tag/%E6%B4%… www.iimedia.cn/tag/%E4%B8%… www.iimedia.cn/tag/%E6%89%… www.iimedia.cn/tag/%E5%8F%… www.iimedia.cn/tag/%E5%98%… www.iimedia.cn/tag/%E6%B2%… www.iimedia.cn/tag/%E6%A6%… www.iimedia.cn/tag/%E6%B3%… www.iimedia.cn/tag/%E9%95%… www.iimedia.cn/tag/%E6%98%… www.iimedia.cn/tag/%E6%B1%… www.iimedia.cn/tag/%E5%BC%… www.iimedia.cn/tag/%E4%B9%… www.iimedia.cn/tag/%E9%87%… www.iimedia.cn/tag/%E4%BF%… www.iimedia.cn/tag/%E5%90%… www.iimedia.cn/tag/%E9%9E%… www.iimedia.cn/tag/%E6%B3%… www.iimedia.cn/tag/%E5%AE%… www.iimedia.cn/tag/%E8%A5%… www.iimedia.cn/tag/%E4%B8%… www.iimedia.cn/tag/%E6%83%… www.iimedia.cn/tag/%E5%8D%… www.iimedia.cn/tag/%E5%A8%… www.iimedia.cn/tag/%E5%BE%… www.iimedia.cn/tag/%E5%B2%… www.iimedia.cn/tag/%E8%81%… www.iimedia.cn/tag/%E5%B8%… www.iimedia.cn/tag/%E6%BC%… www.iimedia.cn/tag/%E6%BB%… www.iimedia.cn/tag/%E8%8C%… www.iimedia.cn/tag/%E6%B7%… www.iimedia.cn/tag/%E6%B1%… www.iimedia.cn/tag/%E8%8A%… www.iimedia.cn/tag/%E6%B9%… www.iimedia.cn/tag/%E5%BB%… www.iimedia.cn/tag/%E8%8F%… www.iimedia.cn/tag/%E6%9F%… www.iimedia.cn/tag/%E5%AE%… www.iimedia.cn/tag/%E7%8F%… www.iimedia.cn/tag/%E7%BB%… www.iimedia.cn/tag/%E6%A0%… www.iimedia.cn/tag/%E8%BF%… www.iimedia.cn/tag/%E8%82%… www.iimedia.cn/tag/%E5%91%… www.iimedia.cn/tag/%E5%8D%… www.iimedia.cn/tag/%E5%BC%… www.iimedia.cn/tag/%E9%BD%… www.iimedia.cn/tag/%E6%80%… www.iimedia.cn/tag/%E9%9F%… www.haowencm.com/list/%E5%8C… www.haowencm.com/list/%E4%B8… www.haowencm.com/list/%E5%B9… www.haowencm.com/list/%E6%B7… www.haowencm.com/list/%E5%A4… www.haowencm.com/list/%E6%9D… www.haowencm.com/list/%E5%8D… www.haowencm.com/list/%E6%B5… www.haowencm.com/list/%E9%87… www.haowencm.com/list/%E9%9D… www.haowencm.com/list/%E5%A4… www.haowencm.com/list/%E5%AE… www.haowencm.com/list/%E5%8E… www.haowencm.com/list/%E6%88… www.haowencm.com/list/%E6%AD… www.haowencm.com/list/%E5%93… www.haowencm.com/list/%E6%B2… www.haowencm.com/list/%E8%A5… www.haowencm.com/list/%E9%95… www.haowencm.com/list/%E9%95… www.haowencm.com/list/%E7%A6… www.haowencm.com/list/%E9%83… www.haowencm.com/list/%E7%9F… www.haowencm.com/list/%E8%8B… www.haowencm.com/list/%E4%BD… www.haowencm.com/list/%E4%B8… www.haowencm.com/list/%E6%97… www.haowencm.com/list/%E7%83… www.haowencm.com/list/%E5%A4… www.haowencm.com/list/%E5%90… www.haowencm.com/list/%E5%8D… www.haowencm.com/list/%E5%8D… www.haowencm.com/list/%E6%98… www.haowencm.com/list/%E6%B8… www.haowencm.com/list/%E6%B7… www.haowencm.com/list/%E5%94… www.haowencm.com/list/%E4%B9… www.haowencm.com/list/%E8%B4… www.haowencm.com/list/%E6%B5… www.haowencm.com/list/%E5%85… www.haowencm.com/list/%E9%93… www.haowencm.com/list/%E8%A5… www.haowencm.com/list/%E5%91… www.haowencm.com/list/%E6%B3… www.haowencm.com/list/%E5%8C… www.haowencm.com/list/%E5%8D… www.haowencm.com/list/%E5%A4… www.haowencm.com/list/%E5%BE… www.haowencm.com/list/%E6%BD… www.haowencm.com/list/%E5%B8… www.haowencm.com/list/%E9%84… www.haowencm.com/list/%E7%BB… www.haowencm.com/list/%E6%B5… www.haowencm.com/list/%E7%9B… www.haowencm.com/list/%E9%82… www.haowencm.com/list/%E4%B8… www.haowencm.com/list/%E6%B4… www.haowencm.com/list/%E4%B8… www.haowencm.com/list/%E6%89… www.haowencm.com/list/%E5%8F… www.haowencm.com/list/%E5%98… www.haowencm.com/list/%E6%B2… www.haowencm.com/list/%E6%A6… www.haowencm.com/list/%E6%B3… www.haowencm.com/list/%E9%95… www.haowencm.com/list/%E6%98… www.haowencm.com/list/%E6%B1… www.haowencm.com/list/%E5%BC… www.haowencm.com/list/%E4%B9… www.haowencm.com/list/%E9%87… www.haowencm.com/list/%E4%BF… www.haowencm.com/list/%E5%90… www.haowencm.com/list/%E9%9E… www.haowencm.com/list/%E6%B3… www.haowencm.com/list/%E5%AE… www.haowencm.com/list/%E8%A5… www.haowencm.com/list/%E4%B8… www.haowencm.com/list/%E6%83… www.haowencm.com/list/%E5%8D… www.haowencm.com/list/%E5%A8… www.haowencm.com/list/%E5%BE… www.haowencm.com/list/%E5%B2… www.haowencm.com/list/%E8%81… www.haowencm.com/list/%E5%B8… www.haowencm.com/list/%E6%BC… www.haowencm.com/list/%E6%BB… www.haowencm.com/list/%E8%8C… www.haowencm.com/list/%E6%B7… www.haowencm.com/list/%E6%B1… www.haowencm.com/list/%E8%8A… www.haowencm.com/list/%E6%B9… www.haowencm.com/list/%E5%BB… www.haowencm.com/list/%E8%8F… www.haowencm.com/list/%E6%9F… www.haowencm.com/list/%E5%AE… www.haowencm.com/list/%E7%8F… www.haowencm.com/list/%E7%BB… www.haowencm.com/list/%E6%A0… www.haowencm.com/list/%E8%BF… www.haowencm.com/list/%E8%82… www.haowencm.com/list/%E5%91… www.haowencm.com/list/%E5%8D… www.haowencm.com/list/%E5%BC… www.haowencm.com/list/%E9%BD… www.haowencm.com/list/%E6%80… www.haowencm.com/list/%E9%9F… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea… aim.baidu.com/product/sea…
immediate和deep
immediate:当watch第一次加载或者首次绑定的时候,需要监听和获取data中的状态,那么就可以使用immediate,设置为true,该属性值为布尔值
deep:watch监听的值为对象的时候,可以使用该属性进行监听对象深层次的属性变化,
注意事项:
deep默认是false,使用的时候,需要自行添加deep:true ,deep和immediate的值一样,是布尔值
实例
<li>{{ immediateNameTip }}</li>
data() {
return {
immediateName: "immediateName原始值",
immediateNameTip: "immediateName改变时的提示文字",
};
},
immediateName: {
handler(newVal, oldVal) {
console.log("immediate表示最初监听值得时候,也执行这段代码");
setTimeout(() => {
this.immediateNameTip =
"immediateName添加immediate,初次绑定也会执行";
}, 2000);
},
immediate: true,
deep: true, // 只针对对象的深层次属性变化
},
当设置了immediate为true的时候,首次进来immediateNameTip在定时器执行之后,就会发生更改。
deep这里不再举例子,大家可以自己在实战中去使用和学习。