watch
The Watch API is exactly equivalent to a component listener property. Watch needs to listen for specific data sources and perform side effects in callback functions. By default, it is also lazy, meaning that the callback is executed only when the source being listened to changes, and it takes three arguments
- A reactive reference or getter that you want to listen for
- A callback
- Optional configuration options
Listening to a single data source
The listener data source can be a getter function that returns a value, or it can be directly ref:
Const state = reactive({count: 0}) watch(() => state.count, (count, prevCount) => {/*... do some thing... Const count = ref(0) watch(count, (count, prevCount) => {/* prevCount, prevCount, prevCount, prevCount, prevCount, prevCount, prevCount, prevCount, prevCount, prevCount, prevCount, prevCount, prevCount) do some thing... * /})Copy the code
Listening to multiple data sources
If you change the source of the listener simultaneously in the same function, the listener will still execute only once:
setup() { const firstName = ref('') const lastName = ref('') watch([firstName, lastName], (newValues, prevValues) => { console.log(newValues, PrevValues)}) // Note that multiple synchronization changes trigger the listener only once const changeValues = () => {firstname.value = 'John' lastname.value = 'Smith' // print ["John", "Smith"] ["", ""] } return { changeValues } }Copy the code
Listen for reactive objects
Use listeners to compare the values of an array or object that are reactive and require it to have a copy of the values
const numbers = reactive([1, 2, 3, 4]) watch( () => [...numbers], (numbers, prevNumbers) => { console.log(numbers, PrevNumbers)}) Numbers. Push (5) / / logs: [1, 2, 3, 4, 5] [1, 2, 3, 4]Copy the code
watchEffect
To automatically apply and reapply side effects based on reactive state, we can use the watchEffect function. It executes a function passed in immediately, tracing its dependencies responsively, and rerunking the function when its dependencies change
- It is executed immediately, actively once as the page loads, to collect dependencies
- Instead of passing something to listen for, it can automatically sense code dependencies and just pass a callback function
- It can’t get the value of the previous data
- Its return value is used to stop the listener
import { ref, reactive, watchEffect } from "vue"; const age = ref(18); const watchAge = ref(0); const doubleAge = () => { watchAge.value = age.value * 2; }; const stop = watchEffect(() => { if (watchAge.value < 60) { doubleAge(); } else { stop(); // Stop listening}});Copy the code
(\ _ /) (*. *) />❤️