En fait, je pense que ce truc est inutile, alors ne l'utilisez pas, hahahahaha !
Comment dire, vous pouvez comprendre que les fonctions de watch et watchEffect sont les mêmes.
watch
: affiche la source de dépendance spécifiée et exécute la fonction de rappel lorsque la source de dépendance est mise à jour. watchEffect
: collecte automatiquement les sources de dépendance et se réexécute lorsque les sources de dépendance sont mises à jour. watch
:显示指定依赖源,依赖源更新时执行回调函数。watchEffect
:自动收集依赖源,依赖源更新时候重新执行自身。
watchEffect 如果存在的话,组件初始化的时候就会自动自行一次,不需要像 watch 一样设置立即执行。
watch 每次回调之后是可以获取到最新值和上一次的老值,但是 watchEffect 是拿不到的。
watchEffect 不需要指定监听的属性,他会自动进行依赖收集,只要我们回调中使用了响应式的属性,那么这些属性在变更之后这个回调都会执行,不像 watch 只能监听指定的属性。
使用的时候也是需要引入。
记住一点哈, watch 可以代替 watchEffect,但是 watchEffect 不能替代 watch。
总结:能用 watch 就不要用 watchEffect。
首先我们写一个简单的 watchEffect 侦听器。
<template> <div> <h2>{{name}}</h2> <button @click="btn">修改name</button> </div> </template> <script> import { ref, watchEffect } from "vue"; export default { name: "App", setup() { const name = ref("我是????????."); function btn() { name.value = "????????."; } const res = watchEffect(() => { console.log("watchEffect 执行了"); }); return { name, btn }; } }; </script>
记住 watchEffect 使用也是需要先引入的,不然不好使哈,然后我们保存上面的代码,然后刷新页面看一下执行结果。
我们发现哈,我们一刷新页面,控制台直接打印了我们输出的内容,所以说呢,watchEffect 组件一加载完就会执行。
我们看到,watchEffect 使用的时候并没有设置监听哪个参数,只有一个回调函数,因为他会自动进行依赖收集,只要我们回调中使用了响应式的属性,那么这些属性在变更之后这个回调都会执行。
比如我们监听 name 的情况。
<template> <div> <h2>{{name}}</h2> <button @click="btn">修改name</button> </div> </template> <script> import { ref, watchEffect } from "vue"; export default { name: "App", setup() { const name = ref("我是????????."); function btn() { name.value = "????????."; } const res = watchEffect(() => { console.log(name.value); }); return { name, btn }; } }; </script>
我们在回调函数打印一下 name 的值。
上面的案例是用来监听一个基本数据,如果监听一个对象呢?
其实也是一样的哈。
<template> <div> <h2>{{boy.age}}</h2> <button @click="boy.age++">修改name</button> </div> </template> <script> import { ref, watchEffect, reactive } from "vue"; export default { name: "App", setup() { const boy = reactive({ name: "我是????????.", age: 10 }); const res = watchEffect(() => { console.log(boy.age); }); return { boy }; } }; </script>
上边代码呢,一个按钮,每次点击让 boy 对象里面的 age 加一操作,然后监听一下 age 的新值
可以看到是完全没有问题的哈!
上边说过了哈,只要我们回调中使用了响应式的属性,那么这些属性在变更之后这个回调都会执行,不像 watch 只能监听指定的属性。
啥意思呢,简单理解一下,就是回调里面使用了的话他就执行,没用他就不执行。
就像上面的案例,修改 age 的时候,我们在回调里面打印了 age,在回调里面涉及到 age 了,他就会执行,如果我们这次不使用改变的 age,只打印一句话,看一下能不能执行回调哈。
<template> <div> <h2>{{boy.age}}</h2> <button @click="boy.age++">修改name</button> </div> </template> <script> import { ref, watchEffect, reactive } from "vue"; export default { name: "App", setup() { const boy = reactive({ name: "我是????????.", age: 10 }); const res = watchEffect(() => { console.log("执行了"); }); return { boy }; } }; </script>
刷新保存,点击按钮修改 age 的值,看一下控制台有没有打印 执行了
const res = watchEffect(() => { console.log(boy.age); });
res() // 关闭
<script> import { ref, watchEffect, reactive } from "vue"; export default { name: "App", setup() { const boy = reactive({ name: "我是????????.", age: 10 }); const res = watchEffect(() => { console.log(boy.age); }); res() // 关闭监听 return { boy }; } }; </script>{{boy.age}}
Exécuté
sont imprimés sur la console. #🎜🎜##🎜🎜# Comprenez-vous cette phrase ? Savez-vous quand il a été exécuté ? D'ACCORD. #🎜🎜##🎜🎜#Désactiver la surveillance watchEffect#🎜🎜##🎜🎜#Supposons que nous commencions à utiliser la surveillance watchEffect, mais que dois-je faire si je ne veux pas qu'elle surveille maintenant ? C'est en fait super simple. #🎜🎜#rrreee#🎜🎜#N'avons-nous pas créé un écouteur watchEffect ci-dessus ? Pour fermer, il vous suffit de l'appeler une seule fois et il sera fermé. #🎜🎜#rrreee#🎜🎜#Voir le code spécifique ci-dessous. #🎜🎜#rrreee#🎜🎜#Enregistrez-le et cliquez sur le bouton pour voir l'effet. #🎜🎜#Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!