前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >Vue3生命周期

Vue3生命周期

原创
作者头像
堕落飞鸟
修改2023-05-21 16:14:15
修改2023-05-21 16:14:15
58500
代码可运行
举报
文章被收录于专栏:飞鸟的专栏飞鸟的专栏
运行总次数:0
代码可运行

Vue 3 生命周期

Vue 3 的生命周期函数是在组件创建、更新和销毁的不同阶段执行的一系列钩子函数。这些生命周期函数提供了在组件不同阶段执行自定义逻辑的机会。

组件生命周期钩子函数

Vue 3 的组件生命周期钩子函数可以分为三个主要阶段:创建阶段、更新阶段和销毁阶段。下面是每个阶段的生命周期钩子函数:

创建阶段

  1. beforeCreate:在实例创建之前调用。此时组件实例的响应式数据和事件还未初始化。
  2. created:在实例创建完成后调用。此时组件实例的响应式数据已经初始化,可以访问和操作数据。
  3. beforeMount:在组件挂载之前调用。此时组件的模板已经编译完成,但尚未挂载到 DOM 上。
  4. mounted:在组件挂载完成后调用。此时组件已经被挂载到 DOM 上,可以进行 DOM 操作和访问 DOM 元素。

更新阶段

  1. beforeUpdate:在组件更新之前调用。当组件的响应式数据发生改变时,会触发更新。
  2. updated:在组件更新完成后调用。此时组件的 DOM 已经更新,可以进行一些更新后的操作。

销毁阶段

  1. beforeUnmount:在组件卸载之前调用。此时组件仍然可以访问和操作数据。
  2. unmounted:在组件卸载完成后调用。此时组件已经从 DOM 中移除,不再可用。

示例

下面是一个简单的示例,演示了 Vue 3 生命周期的使用:

代码语言:javascript
代码运行次数:0
复制
<template>
  <div>
    <p>{{ message }}</p>
    <button @click="updateMessage">Update Message</button>
    <button @click="destroyComponent">Destroy Component</button>
  </div>
</template>

<script>
export default {
  data() {
    return {
      message: 'Hello, Vue 3!'
    };
  },
  beforeCreate() {
    console.log('beforeCreate');
  },
  created() {
    console.log('created');
  },
  beforeMount() {
    console.log('beforeMount');
  },
  mounted() {
    console.log('mounted');
  },
  beforeUpdate() {
    console.log('beforeUpdate');
  },
  updated() {
    console.log('updated');
  },
  beforeUnmount() {
    console.log('beforeUnmount');
  },
  unmounted() {
    console.log('unmounted');
  },
  methods: {
    updateMessage() {
      this.message = 'Updated message';
    },
    destroyComponent() {
      this.$destroy();
    }
  }
};
</script>

在上面的示例中,我们定义了一个简单的组件,包含了各个生命周期钩子函数。当组件被创建、更新和销毁时,相应的钩子函数会被调用,并打印相应的信息到控制台。我们还定义了两个按钮,用于更新组件的数据和销毁组件。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Vue 3 生命周期
  • 组件生命周期钩子函数
    • 创建阶段
    • 更新阶段
    • 销毁阶段
  • 示例
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档