vue3的watchEffect和watch其他参数

这篇具有很好参考价值的文章主要介绍了vue3的watchEffect和watch其他参数。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

1、watchEffect基本使用

2、watch 与 watchEffect的异同

3、watch其他参数使用


1、watchEffect基本使用

1 回调函数立即调用

2 回调函数依赖的数据都会被监控

3 深度监控

<template>
  <div>
     <button @click="num++">num++</button>
  </div>
</template>

<script setup>
import { watchEffect,  ref,  reactive } from 'vue'
// watchEffect监控数据
const num =ref(10)
const obj = reactive({
  name: 'zs',
  age: 18,
  boyFriend: {
    name: 'lisi',
    age: 19
  }
})

watchEffect(() => {
  console.log(num.value);
  console.log(obj.boyFriend.name);
})


</script>

<style lang="scss" scoped>

</style>

2、watch 与 watchEffect的异同

1、 相同点 :都可以对数据进行侦听

2、 不同点 :watchEffect回调函数立即调用、对回调函数依赖的数据隐式监控、默认深度监控

watch 和 watchEffect 都能监听响应式数据的变化,不同的是它们监听数据变化的方式不同。

watch 会明确监听某一个响应数据,而 watchEffect 则是隐式的监听回调函数中响应数据。 watch 在响应数据初始化时是不会执行回调函数的, watchEffect在响应数据初始化时就会立即执行回调函数。

3、watch其他参数使用

watchPostEffect() 是watchEffect() 使用 flush: 'post' 选项时的别名。

onInvalidate副作用清理函数

执行时机:下一次副作用执行前

 文章来源地址https://www.toymoban.com/news/detail-819839.html

<script setup >

import {ref, watch} from 'vue'

let sum=ref(0)
let qyz=ref(null)
const sumadd=()=>{
    sum.value++
}

//onInvalidate副作用清理函数
//副作用-发网络请求。开启定时器,控制台输出
watch(sum,(newVal,oldval,onInvalidate)=>{   //数据变了才执行
    //onInvalidate副作用清理函数
    console.log('青阳子')
    console.log('DOM节点',qyz.value.innerHTML)
    onInvalidate(()=>{
        //执行时机:下一次副作用执行前
        console.log(222)
    })
},{
    flush:'post'//拿到dom更新后的值
})
</script>

<template>
<div>hello,world</div>
<div>
     
<h2 ref="qyz">{{ sum }}</h2>
    </div>
<button @click="sumadd">sum++</button>

</template>

<style scoped>

</style>

到了这里,关于vue3的watchEffect和watch其他参数的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Vue3中watch与watchEffect的区别

    给大家打一个比喻 watch:教导主任叫老师看张三和李四是否在睡觉 watchEffect:教导主任叫老师看班上有谁在睡觉,在睡觉的就报告 1.都能监听响应式数据的变化,不同的是监听数据变化的方式不同 2.watch:要明确指出监视的数据 3.watchEffect:不用明确的指出监视的数据(函数中

    2024年02月21日
    浏览(34)
  • Vue3watch 和 watchEffect

    计算属性是通过声明性的计算衍生值,然而有些情况,我们需要在状态变化时执行一些\\\"副作用\\\",例如更改DOM,或是根据异步操作的结果去修改另一处的状态。 一般来说,computed主要是涉及计算某些值的时候使用, watch(Effect)函数主要是监听某个状态,当某个状态改变时才会触

    2024年02月20日
    浏览(29)
  • Vue3的watchEffect的妙用,与watch的区别

    在Vue3中,引入了Composition API,其中的 watchEffect() 函数是一个非常强大和灵活的工具,用于处理响应式数据的变化,使得项目更加弹性和灵活。它与 watch 有所不同,本文将介绍 watchEffect() 的定义、特点、与 watch 的区别以及使用时的注意事项。 watchEffect() 函数用于创建一个自动

    2024年02月16日
    浏览(33)
  • vue全家桶进阶之路32:Vue3 WatchEffect和watch 监听

    在 Vue 3 中, watchEffect 是一个用于监听响应式数据变化的 API。它可以在函数内部自动跟踪数据的依赖,并在依赖变化时重新运行函数。 watchEffect  的作用以及各个参数的功能讲解: watchEffect(effect: (onInvalidate: InvalidateCbRegistrator) = void | (() = void) | Promisevoid, options?: WatchEffectOptio

    2023年04月17日
    浏览(66)
  • Vue3.0 watch和watchEffect监听器:VCA

    在项目中,有时候检测一个变量的值是否反升了变化。通常使用的watch或者使用低效的循环判断。 在次vue中给我们设置了深度监测数据繁盛变化的方法。 1.vue中提供了在watch监听时设置deep:true 就可以实现对对象的深度监听; 2.immediate:true,代表watch里面声明了之后会立马执行han

    2024年02月06日
    浏览(35)
  • vue3中,ref()、reactive()、computed()、watch() 和 watchEffect()的区别

    ref()、reactive()、computed()、watch() 和 watchEffect() 是 Vue 3 中常用的响应式处理函数,它们的主要区别如下: ref():ref() 函数用于将一个普通的 JavaScript 值转化为响应式对象。它返回一个具有 value 属性的对象,我们可以通过访问 value 属性来获取或修改值。当我们对 ref() 返回的对象

    2024年02月22日
    浏览(41)
  • 【Vue3】vue3中的watchEffect使用及其他的API

    目录  一,watchEffect 二,生命周期 三,什么是hooks? 四,toRef  五,其他组合式API 5.1shallowReactiveshallowRef 5.2readonlyshallowReadonly 5.3.toRawmarkRaw 5.4自定义Ref-customRef ​5.5provide$inject 5.6响应式数据的判断 写在最后     1.watch: 既要指明监视的属性,也要指明监视的回调。 2.watchEffect: 不

    2024年02月01日
    浏览(48)
  • Vue Composition API之侦听器watch/watchEffect

    在日常的开发中,很多时候我们需要去对一些状态进行监听,比如当显示学生的成绩列表时,我们使用一个学生的学号student_num作为请求成绩的参数,如果没有监听机制,当学号student_num改变时,我们需要依赖用户的操作去刷新成绩。但是有了侦听器,我们可以通过侦听器去监

    2024年02月08日
    浏览(29)
  • Vue3前端开发,watch数据侦听器的立即执行

    Vue3前端开发,watch数据侦听器的立即执行!实际上,我们可以通过回调函数的后面,再追加一个对象,来设置这个参数,immediate:true.来实现一种立即执行的效果。在页面记载完成后,马上就会执行一次watch. 如上所示,我们在回调函数的后面,追加了一个参数,是一个对象类型

    2024年01月18日
    浏览(38)
  • Vue3前端开发,watch侦听器的深度监听和精确监听

    Vue3前端开发,watch侦听器的深度监听和精确监听!今天和大家分享的内容是,关于watch的深度侦听和精确监听。 首先看一下,第一个案例,练习的是,深度监听的效果。默认是浅的侦听,是不会触发回调函数的。 如图,当我们点击按钮,修改num值的时候,触发了回调函数,在

    2024年01月23日
    浏览(30)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包