vue3中 watchEffect,watchPostEffect,watchSyncEffect的区别,代码示例

其实关于watchEffect,watchPostEffect,watchSyncEffect的区别就是执行的时机不同,watchSyncEffect 是最先执行的,其次是watchEffect,最后才是watchPostEffect,先来看一下vue官网的说明(不想看说明的直接看示例代码就可以了)

watch 的执行时机说明:

watchPostEffect 和 watchSyncEffect 的执行时机说明:

下面是我的示例代码:

<script setup lang="ts">
import {
  ref,
  watchEffect,
  watchPostEffect,
  watchSyncEffect,
  onMounted,
  onBeforeMount,
} from 'vue'

const num = ref(1)
const numInstance = ref(null)

// 输出1 所有组件更新前
watchSyncEffect(() => {
  console.log(num.value * 2, 'watchSyncEffect')
})
// 输出2 父组件更新后,当前组件更新前
watchEffect(() => {
  console.log(num.value * 2, 'watchEffect')
})
// 输出4 当前组件更新后
watchPostEffect(() => {
  console.log(num.value * 2, 'watchPostEffect')
})
// 输出3
onBeforeMount(() => {
  console.log('onMounted')
})
// 输出5
onMounted(() => {
  console.log('onMounted')
})

const addNum = () => {
  num.value++
}
</script>
<template>
  <div>
    <h1 ref="numInstance">{{  num  }}</h1>
    <el-button type="primary"
               @click="addNum">增加</el-button>
  </div>
</template>


<style lang="less" scoped>
</style>

这是控制台的输出:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值