vue3-生命周期钩子函数

在 Vue 3 中,**生命周期函数**是指在组件的不同阶段自动执行的一些特殊函数。这些函数就像组件的"生老病死"的各个阶段,你可以在不同阶段执行不同的操作。

生命周期的主要阶段:

1. **创建阶段**(组件还没有出现在页面上)

  • `setup()`:在组件实例创建之前调用,适合初始化数据。

  • `onBeforeMount()`:在组件挂载到 DOM 之前调用。

2. **挂载阶段**(组件已经被显示在页面上)

  • `onMounted()`:在组件挂载到 DOM 后调用,通常用来操作 DOM 或发起网络请求。

3. **更新阶段**(数据变化后)

  • `onBeforeUpdate()`:在响应式数据更新前调用。

  • `onUpdated()`:在响应式数据更新并渲染完成后调用。

4. **销毁阶段**(组件从页面上移除)

  • `onBeforeUnmount()`:组件被卸载前调用。

  • `onUnmounted()`:组件被完全卸载后调用。

如何使用生命周期函数?

在 Vue 3 中使用 **Composition API**,你可以在 `setup` 里引入这些函数:

javascript

javascript 复制代码
import { ref, onMounted, onUnmounted } from 'vue';

export default {
  setup() {
    const count = ref(0);

    onMounted(() => {
      console.log('组件已经挂载到页面上了!');
    });

    onUnmounted(() => {
      console.log('组件即将被移除!');
    });

    return { count };
  }
};

总结:

生命周期函数让你在不同的组件阶段执行特定的代码,比如初始化数据、监听事件、操作 DOM 或清理资源。

代码解析:

javascript 复制代码
const app = Vue.createApp({
  data() {
    return {
      posts: [], // 定义响应式数据 posts,初始值为空数组
    };
  },
  methods: {
    async fetchPosts() {
      // 定义一个异步方法,用于获取数据
      const res = await fetch("./posts.json"); 
      // 使用 fetch 获取本地 JSON 文件,返回一个 Promise
      const postsData = await res.json();
      // 解析返回的 JSON 数据,并赋值给变量 postsData
      this.posts = postsData;
      // 将获取到的数据赋值给 Vue 的响应式属性 posts
    },
  },
  created() {
    // 生命周期函数:组件实例被创建后立即执行
    this.fetchPosts(); 
    // 调用 fetchPosts 方法,开始获取数据
  },
});

const vm = app.mount("#app");
// 将 Vue 应用实例挂载到 HTML 中 id 为 "app" 的 DOM 元素上
相关推荐
IT_陈寒1 分钟前
React性能优化:这5个Hook技巧让我的组件渲染效率提升50%(附代码对比)
前端·人工智能·后端
智能化咨询17 分钟前
【Linux】【实战向】Linux 进程替换避坑指南:从理解 bash 阻塞等待,到亲手实现能执行 ls/cd 的 Shell
前端·chrome
Anson Jiang20 分钟前
浏览器标签页管理:使用chrome.tabs API实现新建、切换、抓取内容——Chrome插件开发从入门到精通系列教程06
开发语言·前端·javascript·chrome·ecmascript·chrome devtools·chrome插件
掘金安东尼23 分钟前
黑客劫持:周下载量超20+亿的NPM包被攻击
前端·javascript·面试
剑亦未配妥1 小时前
移动端触摸事件与鼠标事件的触发机制详解
前端·javascript
人工智能训练师7 小时前
Ubuntu22.04如何安装新版本的Node.js和npm
linux·运维·前端·人工智能·ubuntu·npm·node.js
Seveny077 小时前
pnpm相对于npm,yarn的优势
前端·npm·node.js
yddddddy8 小时前
css的基本知识
前端·css
昔人'8 小时前
css `lh`单位
前端·css
前端君9 小时前
实现最大异步并发执行队列
javascript