<template> <input type="text" v-model="text1" /> </template> <script setup> import { ref, watch } from 'vue' const text1 = ref('') watch(text1, (newVal, oldVal) => { console.log('监听单个数据', newVal, oldVal) }) </script>
<template> <input type="text" v-model="text1" /> <input type="text" v-model="text2" /> </template> <script setup> import { ref, watch } from 'vue' const text1 = ref('') const text2 = ref('') watch([text1, text2], (newVal, oldVal) => { console.log('监听一组数据', newVal, oldVal) }) </script>
<template> name: <input type="text" v-model="student.name" /> age: <input type="number" v-model="student.age" /> </template> <script setup> import { reactive, watch } from 'vue' const student = reactive({ name: '', age: '' }) watch(student, (newVal, oldVal) => { console.log('newVal', newVal) console.log('oldVal', newVal) }) </script>
watch
에는 세 번째 매개변수인 deep
도 있습니다. > 및 immediate
를 추가하면 효과를 볼 수 있습니다watch
还有第三个参数,deep
和immediate
,可以加上看看效果
<template> name: <input type="text" v-model="student.name" /> age: <input type="number" v-model="student.age" /> </template> <script lang="ts" setup> import { reactive, watch } from 'vue' const student = reactive({ name: '', age: '' }) watch(() => student.name, (newVal, oldVal) => { console.log('newVal', newVal) console.log('oldVal', newVal) }, { deep: true, immediate: true }) </script>
监听对象某一个属性的时候需要用箭头函数
关于watchEffect
,官网是这么介绍的:为了根据响应式状态自动应用和重新应用副作用,我们可以使用watchEffect
方法,它立即执行传入的一个函数,同时响应式追踪其依赖,并在其依赖变更时重新运行该函数。 也就是说,我们并不需要传入一个特定的依赖源,而且它会立即执行一遍回调函数,如果函数产生了副作用,那它就会自动追踪副作用的依赖关系,自动分析出响应源。光看概念可能比较模糊,先来看个最简单的例子:
<template> name: <input type="text" v-model="student.name" /> age: <input type="number" v-model="student.age" /> </template> <script lang="ts" setup> import { reactive, watchEffect } from 'vue' const student = reactive({ name: '', age: '' }) watchEffect(() => { console.log('name: ',student.name, 'age: ', student.age) }) </script>
副作用,那什么是副作用呢,其实很简单,就是在监听之前,我得做一件事。
<template> name: <input type="text" v-model="student.name" /> age: <input type="number" v-model="student.age" /> <h3>{{student.name}}</h3> </template> <script lang="ts" setup> import { reactive, watchEffect } from 'vue' const student = reactive({ name: '', age: '' }) watchEffect((oninvalidate) => { oninvalidate(() => { student.name = '张三' }) console.log('name: ', student.name) }, { // pre 组件更新前; sync:强制效果始终同步; post:组件更新后执行 flush: 'post' // dom加载完毕后执行 }) </script>
监听之前让student.name
赋值为'张三',无论你输入什么值,name
一直都是'张三'
我们用同步语句创建的监听器,会自动绑定到组件实例上,并且会在组件卸载时自动停止,但是,如果我们在异步回调里创建一个监听器,那它就不会绑定到当前组件上,必须手动去停止,防止内存泄漏。 那怎么去停止呢,其实我们只需要调用一下watch
或watchEffect
返回的函数
const stop = watchEffect(() => {}) // 停止监听 unwatch()
用了一遍watch
和watchEffect
之后,发现他俩主要有以下几点区别:
watch
是惰性执行的,而watchEffect
不是,不考虑watch
第三个配置参数的情况下,watch
在组件第一次执行的时候是不会执行的,只有在之后依赖项变化的时候再执行,而watchEffect
是在程序执行到此处的时候就会立即执行,而后再响应其依赖变化执行。
watch
需要传递监听的对象,watchEffect
watchEffect
에 대해 공식 홈페이지에서는 다음과 같이 소개하고 있습니다. 반응 상태에 따라 사이드 이펙트를 자동으로 적용하고 다시 적용하려면 watchEffect 메서드는 종속성을 반응적으로 추적하고 종속성이 변경되면 함수를 다시 실행하는 수신 A 함수를 즉시 실행합니다. 즉, 특정 종속성 소스를 전달할 필요가 없으며 함수가 부작용을 생성하면 자동으로 부작용의 종속성을 추적하고 응답 소스를 자동으로 분석하여 콜백 함수를 실행합니다. 보기만 해도 개념이 모호할 수 있는데 가장 간단한 예부터 살펴보겠습니다. 🎜rrreee🎜watchEffect Side Effect🎜🎜Side Effect란 과연 무엇일까요? 한 가지 일을 해야 합니다. 🎜rrreee🎜모니터링하기 전에 student.name
을 'Zhang San'에 할당하세요. 어떤 값을 입력하든 name
은 항상 'Zhang San'이 됩니다.🎜🎜모니터링 중지🎜🎜 동기 문을 사용하여 생성한 리스너는 구성 요소 인스턴스에 자동으로 바인딩되고 구성 요소가 언로드될 때 자동으로 중지됩니다. 그러나 비동기 콜백에서 리스너를 생성하면 현재 구성 요소에 바인딩되지 않습니다. 메모리 누수를 방지하려면 수동으로 중지해야 합니다. 그렇다면 이를 중지하려면 어떻게 해야 할까요? 실제로 watch
또는 watchEffect
🎜rrreee🎜에서 반환된 함수만 호출하면 됩니다. 차이점🎜🎜은 watch
를 사용합니다. > watchEffect
이후에는 다음과 같은 주요 차이점이 있음을 발견했습니다. 🎜watch
가 느리게 실행됩니다. 그러나 watchEffect
는 그렇지 않습니다. watch
의 세 번째 구성 매개변수를 고려하지 않으면 구성 요소가 처음 실행될 때 watch
가 실행되지 않습니다. . , 나중에 종속성이 변경될 때만 실행되는 반면 watchEffect
는 여기에서 프로그램이 실행될 때 즉시 실행된 다음 종속성 변경에 대한 응답으로 실행됩니다. 🎜🎜watch
는 모니터링 개체를 전달해야 하지만, watchEffect
는 🎜🎜🎜 필요하지 않습니다.위 내용은 vue3의 watch 및 watchEffect 사용 사례 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!