【Vue3】回顾watch,学习watchEffect

举报
小馒头学Python 发表于 2024/03/06 20:28:40 2024/03/06
【摘要】 文章目录🍋回顾watch🍋引入watchEffect🍋watch、watchEffect对比🍋注意事项🍋总结🍋回顾watch在介绍本节的内容之前,我们还是先准备好本节使用的初始代码<template> <div class="person"> <h2>攻击:{{ gongji }}</h2> <h2>防御:{{ fangyu }}</h2> <button @...


🍋回顾watch

在介绍本节的内容之前,我们还是先准备好本节使用的初始代码

<template>
  <div class="person">
    <h2>攻击:{{ gongji }}</h2>
    <h2>防御:{{ fangyu }}</h2>
    <button @click="changeG">攻击点数加一</button>
    <button @click="changeF">防御点数加一</button>
</div>
 </template>
 
 <script lang="ts" setup name="Person11">
    import {ref} from 'vue'
    let gongji = ref(0)
    let fangyu = ref(0)

    function changeG(){
      gongji.value += 1
    }
    function changeF(){
      fangyu.value += 1
    }
   
 </script>
 
 <style scoped>
   .person {
     background-color: skyblue;
     box-shadow: 0 0 10px;
     border-radius: 10px;
     padding: 20px;
   }
   button {
     margin: 0 5px;
   }
 </style>

运行结果如下
请添加图片描述

接下来我们表达我们的需求:当攻击或者防御达到十点的时候给服务器发送请求
如果我们想要使用上节的watch进行实现

<template>
  <div class="person">
    <h2>攻击:{{ gongji }}</h2>
    <h2>防御:{{ fangyu }}</h2>
    <button @click="changeG">攻击点数加一</button>
    <button @click="changeF">防御点数加一</button>
</div>
 </template>
 
 <script lang="ts" setup name="Person11">
    import {ref,watch} from 'vue'
    let gongji = ref(0)
    let fangyu = ref(0)

    function changeG(){
      gongji.value += 1
    }
    function changeF(){
      fangyu.value += 1
    }
    watch([gongji,fangyu],(newValue,oldValue)=>{
      console.log(newValue,oldValue)
    })
   
 </script>
 
 <style scoped>
   .person {
     background-color: skyblue;
     box-shadow: 0 0 10px;
     border-radius: 10px;
     padding: 20px;
   }
   button {
     margin: 0 5px;
   }
 </style>

运行结果如下
在这里插入图片描述

接下来我们从Value中获取新的攻击和防御

watch([gongji,fangyu],(Value)=>{
      let [newG, newF] = Value
      if(newG>=10 || newF>=10){
        console.log('发送请求')
      }
    })

当我们点击九次的时候没有反应
在这里插入图片描述

再点击一次,就会发送请求了
在这里插入图片描述

🍋引入watchEffect

 Vue3 中,watchEffect 是一个非常有用的函数,用于监视响应式数据的变化并执行相应的副作用代码。与 watch 监视特定的数据源不同,watchEffect 会自动追踪其内部的响应式数据,并在这些数据变化时重新运行传入的函数。

上一段中如果我们想要监视多个数据,使其更加方便,那么watchEffect就展现了它的作用

    import {ref,watch,watchEffect} from 'vue'
 watchEffect(()=>{
      if(gongji.value>=10 || fangyu.value>=10){
        console.log('发送请求')
      }
    })

下面依然是两张对比图片
在这里插入图片描述

在这里插入图片描述

🍋watch、watchEffect对比

watchEffect可以立即运行一个函数

watch对比watchEffect

  1. 都能监听响应式数据的变化,不同的是监听数据变化的方式不同

  2. watch:要明确指出监视的数据

  3. watchEffect:不用明确指出监视的数据(函数中用到哪些属性,那就监视哪些属性)。

🍋注意事项

避免在 watchEffect 中执行会引起无限循环的操作,比如直接修改 state 中的属性。
如果需要手动清除 watchEffect,可以将其返回的清除函数保存起来,并在适当的时机调用。

Vue3 中的 watchEffect 是一个强大而灵活的工具,可以帮助我们更方便地处理响应式数据的变化,并执行相应的副作用代码。

🍋总结

合理的使用watch和watchEffect可以让我们的开发变得更加高效

【声明】本内容来自华为云开发者社区博主,不代表华为云及华为云开发者社区的观点和立场。转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。