Vue 3中常用的生命周期钩子和监听器的操作方法
前言
分析常用的一些生命周期钩子和监听器可以帮助我们在组件中处理数据加载、状态变化和响应式更新
1. onMounted
生命周期钩子,在组件挂载后执行。它适合用于初始化数据加载或执行一次性的操作
<template> <div> <p>当前用户ID: {{ userId }}</p> <button @click="fetchUserData">加载用户数据</button> </div> </template> <script setup> import { ref, onMounted } from 'vue'; import UserDataApi from 'path-to-your-api'; // 假设这是你的数据接口 const userId = ref(null); const userData = ref(null); onMounted(async () => { // 初始化加载数据 await fetchUserData(); }); const fetchUserData = async () => { const response = await UserDataApi.getUserData(); userId.value = response.userId; userData.value = response.userData; }; </script>
2. watch
监听指定的响应式数据,并在数据变化时执行回调函数
有两种形式:基础的 watch 和 watchEffect
<template> <div> <p>当前计数: {{ count }}</p> <button @click="increment">增加计数</button> </div> </template> <script setup> import { ref, watch } from 'vue'; const count = ref(0); watch(count, (newValue, oldValue) => { console.log(`计数从 ${oldValue} 变为 ${newValue}`); }); const increment = () => { count.value++; }; </script>
watchEffect 在其依赖变化时立即执行传入的回调函数
<template> <div> <p>当前时间: {{ currentTime }}</p> </div> </template> <script setup> import { ref, watchEffect } from 'vue'; const currentTime = ref(new Date()); watchEffect(() => { console.log('更新当前时间'); currentTime.value = new Date(); }); // 模拟定时更新时间 setInterval(() => { currentTime.value = new Date(); }, 1000); </script>
3. computed
computed: 计算属性,基于响应式数据派生出新的数据,并自动缓存结果
<template> <div> <p>原始数值: {{ originalValue }}</p> <p>加倍后的值: {{ doubledValue }}</p> <button @click="increment">增加数值</button> </div> </template> <script setup> import { ref, computed } from 'vue'; const originalValue = ref(5); const doubledValue = computed(() => originalValue.value * 2); const increment = () => { originalValue.value++; }; </script>
4. 其他
reactive: 创建一个完全响应式的对象或数组
<template> <div> <p>当前用户: {{ user.name }}</p> <button @click="changeUserName">修改用户名</button> </div> </template> <script setup> import { reactive } from 'vue'; const user = reactive({ name: 'John Doe', age: 30 }); const changeUserName = () => { user.name = 'Jane Smith'; }; </script>
ref: 创建一个响应式的引用,通常用于包装基本类型值
<template> <div> <p>当前计数: {{ count.value }}</p> <button @click="increment">增加计数</button> </div> </template> <script setup> import { ref } from 'vue'; const count = ref(0); const increment = () => { count.value++; }; </script>
到此这篇关于Vue 3中常用的生命周期钩子和监听器的详细分析的文章就介绍到这了,更多相关Vue 3生命周期钩子和监听器内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
BuildAdmin elementPlus自定义表头添加tooltip方法示例
这篇文章主要介绍了BuildAdmin elementPlus 自定义表头,添加tooltip实现方法示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-09-09vue如何使用element ui表格el-table-column在里面做判断
这篇文章主要介绍了vue如何使用element ui表格el-table-column在里面做判断问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2024-08-08
最新评论