学习Vue3——生命周期

简单来说就是一个组件从创建到销毁的过程称为生命周期

Vue 2 生命周期钩子函数Vue 3 生命周期钩子函数含义
beforeCreatesetup数据观测和初始化事件还未开始,此时 data 的响应式追踪、event/watcher 都还没有被设置,也就是说不能访问到data、computed、watch、methods上的方法和数据
createdsetup实例创建完成,实例上配置的 options 包括 data、computed、watch、methods 等都配置完成,但是此时渲染得节点还未挂载到 DOM,所以不能访问到 $el 属性
beforeMountonBeforeMount在挂载开始之前被调用,相关的render函数首次被调用。实例已完成以下的配置:编译模板,把data里面的数据和模板生成html。此时还没有挂载html到页面上
mountedonMounted在el被新创建的 vm.$el 替换,并挂载到实例上去之后调用。实例已完成以下的配置:用上面编译好的html内容替换el属性指向的DOM对象。完成模板中的html渲染到html 页面中。此过程中进行ajax交互
beforeUpdateonBeforeUpdate响应式数据更新时调用,此时虽然响应式数据更新了,但是对应的真实 DOM 还没有被渲染
updatedonUpdated在由于数据更改导致的虚拟DOM重新渲染和打补丁之后调用。此时 DOM 已经根据响应式数据的变化更新了。调用时,组件 DOM已经更新,所以可以执行依赖于DOM的操作。然而在大多数情况下,应该避免在此期间更改状态,因为这可能会导致更新无限循环
beforeDestroyonBeforeUnmount实例销毁之前调用。这一步,实例仍然完全可用,this 仍能获取到实例
destroyedonUnmounted实例销毁后调用,调用后,Vue 实例指示的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁。

在我们使用Vue3 组合式API 是没有 beforeCreatecreated 这两个生命周期的,取而代之是setup

在这里插入图片描述

父组件
vue3组件是直接引入,不需要声明

<template>
  <LifeCycle v-if="flag" />
  <button @click="flag = !flag">创建-销毁</button>
</template>

<script setup lang="ts">
import LifeCycle from './components/LifeCycle.vue'
import { ref } from 'vue'
let flag = ref(true)
</script>

子组件

<template>
  <div>生命周期</div>
  <div ref="domRef">{{ str }}</div>
  <button @click="change">修改</button>
</template>

<script setup lang="ts">
import {
  ref,
  onBeforeMount,
  onMounted,
  onBeforeUpdate,
  onUpdated,
  onBeforeUnmount,
  onUnmounted
} from 'vue'
let str = ref('我是张三')
let domRef = ref()
const change = () => {
  str.value = '我是李四'
}
// beforeCreate created setup语法糖模式下是没有这两个生命周期的
console.log('setup')

// 创建
// onBeforeMount 读不到dom onMounted 可以读取dom
onBeforeMount(() => {
  // 创建之前===>undefined
  console.log(`创建之前===>${domRef.value?.innerText}`)
})
onMounted(() => {
  // 创建完成===>我是张三
  console.log(`创建完成===>${domRef.value.innerText}`)
})

// 更新
// onBeforeUpdate 获取是更新之前的dom ,onUpdated 获取更新后的dom
onBeforeUpdate(() => {
  // 我是张三
  console.log('更新之前===>', domRef.value.innerText)
})
onUpdated(() => {
  // 我是李四
  console.log('更新完成===>', domRef.value.innerText)
})

// 卸载
onBeforeUnmount(() => {
  console.log('卸载之前')
})
onUnmounted(() => {
  console.log('卸载完成')
})
</script>

在这里插入图片描述

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue3与Vue2在生命周期上有一些显著的变化。Vue3中的生命周期函数相较于Vue2有所简化和优化,旨在提高性能和开发体验。 首先,Vue3中去掉了Vue2中的beforeCreate和created两个生命周期钩子函数。这是因为在Vue3中引入了Composition API,允许我们使用setup函数来替代beforeCreate和created的功能。setup函数会在组件实例被创建之前调用,可以用来进行变量的初始化和副作用的处理。 其次,Vue3中引入了一个新的生命周期钩子函数——beforeMount。在组件即将被挂载到DOM之前,beforeMount函数会被调用。这个阶段可以用来进行一些准备工作,比如请求数据或者绑定事件。 接下来是mount阶段,即挂载阶段,此阶段对应Vue2中的mounted生命周期函数。在mount阶段,组件的template被编译成真实的DOM元素,并插入到页面中。我们可以在mount函数中执行一些与DOM相关的操作。 接着是update阶段。在Vue2中,我们可以使用beforeUpdate和updated这两个生命周期钩子函数来监听数据的变化,并在数据更新后执行相应的操作。而在Vue3中,我们可以使用watchEffect函数来实现相同的效果。watchEffect会监听组件中响应式属性的变化,并自动执行相应的回调函数。 最后是unmount阶段,即组件被卸载的阶段。在Vue3中,我们可以使用onUnmounted函数来代替Vue2中的beforeDestroy和destroyed生命周期函数。onUnmounted会在组件被销毁之前执行,我们可以在这个时候做一些清理工作,比如取消订阅或者清除定时器。 总的来说,Vue3中的生命周期函数进行了一些优化和简化,提高了性能和开发体验。通过引入Composition API和watchEffect函数,我们可以更加灵活地处理组件的生命周期
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值