>웹 프론트엔드 >View.js >vue3의 watch 및 watchEffect 사용 사례 분석

vue3의 watch 및 watchEffect 사용 사례 분석

王林
王林앞으로
2023-05-12 21:43:04947검색

    watch

    watch는 단일 데이터를 모니터링합니다.

    <template>
        <input type="text" v-model="text1" />
    </template>
    
    <script setup>
    import { ref, watch } from &#39;vue&#39;
    const text1 = ref(&#39;&#39;)
    
    watch(text1, (newVal, oldVal) => {
        console.log(&#39;监听单个数据&#39;, newVal, oldVal)
    })
    </script>

    watch는 여러 데이터를 모니터링합니다.

    <template>
        <input type="text" v-model="text1" />
        <input type="text" v-model="text2" />
    </template>
    
    <script setup>
    import { ref, watch } from &#39;vue&#39;
    const text1 = ref(&#39;&#39;)
    const text2 = ref(&#39;&#39;)
    
    watch([text1, text2], (newVal, oldVal) => {
        console.log(&#39;监听一组数据&#39;, newVal, oldVal)
    })
    </script>

    watch 모니터 객체

    <template>
        name: <input type="text" v-model="student.name" />
        age: <input type="number" v-model="student.age" />
    </template>
    <script setup>
    import { reactive, watch } from &#39;vue&#39;
    const student = reactive({
        name: &#39;&#39;,
        age: &#39;&#39;
    })
    watch(student, (newVal, oldVal) => {
        console.log(&#39;newVal&#39;, newVal)
        console.log(&#39;oldVal&#39;, newVal)
    })
    </script>

    watch에는 세 번째 매개변수인 deep도 있습니다. > 및 immediate를 추가하면 효과를 볼 수 있습니다watch还有第三个参数,deepimmediate,可以加上看看效果

    watch监听对象的某一个值

    <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 &#39;vue&#39;
    const student = reactive({
        name: &#39;&#39;,
        age: &#39;&#39;
    })
    watch(() => student.name, (newVal, oldVal) => {
        console.log(&#39;newVal&#39;, newVal)
        console.log(&#39;oldVal&#39;, newVal)
    }, {
        deep: true,
        immediate: true
    })
    </script>

    监听对象某一个属性的时候需要用箭头函数 

    watchEffect

    关于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 &#39;vue&#39;
    
    const student = reactive({
        name: &#39;&#39;,
        age: &#39;&#39;
    })
    watchEffect(() => {
        console.log(&#39;name: &#39;,student.name, &#39;age: &#39;, student.age)
    })
    </script>

    watchEffect副作用

    副作用,那什么是副作用呢,其实很简单,就是在监听之前,我得做一件事。

    <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 &#39;vue&#39;
    
    const student = reactive({
        name: &#39;&#39;,
        age: &#39;&#39;
    })
    watchEffect((oninvalidate) => {
        oninvalidate(() => {
            student.name = &#39;张三&#39;
        })
        console.log(&#39;name: &#39;, student.name)
    }, {
        // pre 组件更新前; sync:强制效果始终同步; post:组件更新后执行
        flush: &#39;post&#39;  // dom加载完毕后执行
    })
    </script>

    监听之前让student.name赋值为'张三',无论你输入什么值,name一直都是'张三'

    停止监听

    我们用同步语句创建的监听器,会自动绑定到组件实例上,并且会在组件卸载时自动停止,但是,如果我们在异步回调里创建一个监听器,那它就不会绑定到当前组件上,必须手动去停止,防止内存泄漏。 那怎么去停止呢,其实我们只需要调用一下watchwatchEffect返回的函数

    const stop = watchEffect(() => {})
    
    // 停止监听
    unwatch()

    区别

    用了一遍watchwatchEffect之后,发现他俩主要有以下几点区别:

    • watch是惰性执行的,而watchEffect不是,不考虑watch第三个配置参数的情况下,watch在组件第一次执行的时候是不会执行的,只有在之后依赖项变化的时候再执行,而watchEffect是在程序执行到此处的时候就会立即执行,而后再响应其依赖变化执行。

    • watch需要传递监听的对象,watchEffect

      watch는 개체의 특정 값을 모니터링합니다
    • rrreee
    개체의 특정 속성을 모니터링할 때는 화살표를 사용해야 합니다. 함수 🎜🎜 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

    성명:
    이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제