理解 Vue 的 setup 应用程序钩子

news/2025/1/8 18:54:21/文章来源:https://www.cnblogs.com/Amd794/p/18441608

title: 理解 Vue 的 setup 应用程序钩子
date: 2024/9/30
updated: 2024/9/30
author: cmdragon

excerpt:
摘要:本文详细介绍了Vue 3中setup函数的应用,包括其概念、特性、使用方法及重要性。setup函数作为组合API的核心,在组件实例化前被调用,用于设置响应式状态、计算属性、方法和生命周期钩子,支持在SSR和CSR中使用。

categories:

  • 前端开发

tags:

  • Vue
  • setup
  • 组件
  • 响应式
  • 计算属性
  • 生命周期
  • 方法

image
image

扫描二维码关注或者微信搜一搜:编程智域 前端至全栈交流与成长

在 Vue 3 中,setup 函数是组合 API 的核心部分,它为开发者提供了一种新的方式来组织和使用组件的逻辑。在 setup 函数内,可以定义组件的响应式状态、计算属性、方法以及生命周期钩子等

目录

  1. 什么是 setup 函数?
  2. setup 函数的特性
  3. 如何使用 setup 函数
    • 1. 创建响应式状态
    • 2. 定义计算属性
    • 3. 定义方法
    • 4. 使用生命周期钩子
  4. 总结

什么是 setup 函数?

setup 是一个特殊的生命周期函数,在组件实例化之前调用,用于设置组件的响应式状态、计算属性、方法和其他功能。当组件被创建时,Vue 会先调用 setup 函数,并将其返回的对象作为组件的响应式属性。

作用范围

  • 服务器端和客户端setup 可以在服务器端渲染(SSR)和客户端渲染(CSR)中使用。

setup 函数的特性

  1. 提前执行setup 在组件实例创建之前调用。
  2. 返回值:可以返回一个对象,这些值将作为组件的属性和方法可以在模板中使用。
  3. 访问 props 和 contextsetup 函数接收两个参数:propscontext(包含 attrs, slots, 和 emit)。
  4. 支持响应式 API:可以直接使用 Vue 的响应式 API,比如 refreactive

如何使用 setup 函数

1. 创建响应式状态

使用 refreactive 进行状态管理:

<template><div><h1>{{ count }}</h1><button @click="increment">Increment</button></div>
</template><script setup>
import { ref } from 'vue';const count = ref(0);const increment = () => {count.value++;
};
</script>

2. 定义计算属性

计算属性可以通过 computed 来定义:

<template><div><h1>{{ doubledCount }}</h1><button @click="increment">Increment</button></div>
</template><script setup>
import { ref, computed } from 'vue';const count = ref(0);const increment = () => {count.value++;
};const doubledCount = computed(() => count.value * 2);
</script>

3. 定义方法

可以在 setup 中定义方法,并将其返回:

<template><div><h1>{{ message }}</h1><button @click="changeMessage">Change Message</button></div>
</template><script setup>
import { ref } from 'vue';const message = ref('Hello, Vue 3!');const changeMessage = () => {message.value = 'Message Changed!';
};
</script>

4. 使用生命周期钩子

可以在 setup 中使用生命周期钩子,比如 onMountedonUnmounted

<template><div><h1>{{ count }}</h1><button @click="increment">Increment</button></div>
</template><script setup>
import { ref, onMounted, onUnmounted } from 'vue';const count = ref(0);const increment = () => {count.value++;
};// 使用 onMounted 生命周期钩子
onMounted(() => {console.log('Component is mounted!');
});// 使用 onUnmounted 生命周期钩子
onUnmounted(() => {console.log('Component is unmounted!');
});
</script>

总结

setup 函数是 Vue 3 中一个非常强大的功能,允许开发者以更灵活和模块化的方式组织组件逻辑。通过合理使用 setup 函数及其提供的 API,你可以提高组件之间的可重用性和可维护性。

关键要点

  1. 响应式状态管理:使用 refreactive 轻松管理状态。
  2. 计算属性和方法:通过 computed 定义计算属性以及在 setup 中定义方法。
  3. 生命周期钩子:可以在 setup 中使用各种生命周期钩子来处理组件的生命周期。
  4. 优化性能setup 函数的使用能够在组件之间更好地组织逻辑,提高性能和可维护性。

余下文章内容请点击跳转至 个人博客页面 或者 扫码关注或者微信搜一搜:编程智域 前端至全栈交流与成长,阅读完整的文章:理解 Vue 的 setup 应用程序钩子 | cmdragon's Blog

往期文章归档:

  • 深入理解 Nuxt.js 中的 app:data:refresh 钩子 | cmdragon's Blog
  • 深入理解 Nuxt.js 中的 app:error:cleared 钩子 | cmdragon's Blog
  • 深入理解 Nuxt.js 中的 app:error 钩子 | cmdragon's Blog
  • 深入理解 Nuxt 中的 app created 钩子 | cmdragon's Blog
  • Nuxt Kit 实用工具的使用示例 | cmdragon's Blog
  • 使用 Nuxt Kit 的构建器 API 来扩展配置 | cmdragon's Blog
  • Nuxt Kit 使用日志记录工具 | cmdragon's Blog
  • Nuxt Kit API :路径解析工具 | cmdragon's Blog
  • Nuxt Kit中的 Nitro 处理程序 | cmdragon's Blog
  • Nuxt Kit 中的模板处理 | cmdragon's Blog
  • Nuxt Kit 中的插件:创建与使用 | cmdragon's Blog
  • Nuxt Kit 中的布局管理 | cmdragon's Blog
  • Nuxt Kit 中的页面和路由管理 | cmdragon's Blog
  • Nuxt Kit 中的上下文处理 | cmdragon's Blog
  • Nuxt Kit 组件管理:注册与自动导入 | cmdragon's Blog
  • Nuxt Kit 自动导入功能:高效管理你的模块和组合式函数 | cmdragon's Blog
  • 使用 Nuxt Kit 检查模块与 Nuxt 版本兼容性 | cmdragon's Blog
  • Nuxt Kit 的使用指南:从加载到构建 | cmdragon's Blog
  • Nuxt Kit 的使用指南:模块创建与管理 | cmdragon's Blog
  • 使用 nuxi upgrade 升级现有nuxt项目版本 | cmdragon's Blog
  • 如何在 Nuxt 3 中有效使用 TypeScript | cmdragon's Blog
  • 使用 nuxi preview 命令预览 Nuxt 应用 | cmdragon's Blog

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/806130.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

记一次Razor Pages无法编译问题及解决

解决方案写在前面:更新Visual Studio及相关组件,本人版本自17.8.0更新至17.11.4 缘起于公司的一个业务接口,在有一些信息需要在应用内嵌的webview中展示,信息不少,涉及的前端技术不复杂,但是拼字符串太罗嗦,所以想到了添加一个Razor页面,所以,常规逻辑,在服务上注册A…

Svnlook使用浅谈(配置svn上传必须添加备注和删除权限)

在配置svn上传必须添加备注和删除权限前,我先隆重介绍下今天用到的svn命令svnlook。svnlook是检验Subversion版本库不同方面的命令行工具,不会对版本库有任何修改,只是查看,包括作者信息、文件内容、更改历史、文件大小、属性等。当然它有自己的独特语法 (1)语法格式:sv…

php: 查看opcache的使用情况

一,代码: opcache的各项参数设置效果怎么样?是否需要调整?我们需要了解一个opcache使用情况的统计,以供调整参数时处理 看php代码: <?php // 确保已经启用了Opcache if (extension_loaded(Zend OPcache) && function_exists(opcache_get_status)) {$status = …

adb命令输入中文字符

前言: adb 可以输入英文的文本,由于不支持unicode编码,所以无法输入中文,github上有个国外的大神写了个ADBKeyBoard输入法的apk,完美支持unicode编码,也能输入中文和其它字符及表情.解决方法: 1、https://zhangka.lanzouw.com/iKPQM2b7q9wd  密码:ah9d,下载并安装apk…

在 win10 2021 LTSC 上安装配置 wsl2 和 ubuntu

在 win10 2021 LTSC 上安装配置 wsl2 和 ubuntu 的过程: 参考官方文档:https://learn.microsoft.com/zh-cn/windows/wsl/install-manual(最后一步安装ubuntu发行版时,请自己解压, 然后拷贝到其他目录 再运行 ubuntu.exe, 否则默认放到了c盘 )win10系统启用wsl2:wsl --inst…

platformio创建工程过慢问题

在vscode安装platformio插件后,打开插件,等待platformio code安装完成后,关闭vscode打开任务管理器,结束进程platformio.exe和所有的Python.exe进程全部结束打开文件C:\用户名\你的用户名.platformio\penv\pip.conf,修改为如下配置[global] index-url = https://mirrors.h…

南沙C++信奥赛陈老师解一本通题:1945:【09NOIP普及组】多项式输出

​【题目描述】一元 nn 次多项式可用如下的表达式表示:f(x)=anxn+an−1xn−1+...+a1x+a0,an≠0f(x)=anxn+an−1xn−1+...+a1x+a0,an≠0其中,aixii 称为i次项,ai称为ii次项的系数。给出一个一元多项式各项的次数和系数,请按照如下规定的格式要求输出该多项式: 1. 多项式中…

PART0-Oracle数据库介绍

1. Oracle数据库介绍 1.1. 关于关系型的数据库 每个组织都有必须存储和管理的信息,以满足其需求。例如,公司必须收集和维护员工的人力资源记录。这些信息必须对需要它的人可用。信息系统是一个用于存储和处理信息的正式系统。 信息系统可以是一组包含文件夹的纸箱,以及存储和…

六个核桃科技有限公司——团队展示

这个作业属于哪个课程 https://edu.cnblogs.com/campus/hniit/AI2022这个作业要求在哪里 https://edu.cnblogs.com/campus/hniit/AI2022/homework/13280团队名称 六个核桃科技有限公司这个作业的目标 让湖南信息学院人工智能专业成绩提高10%其他参考文献 kimi作业正文 智慧核桃…

电影《浴火之路》百度云下载资源/迅雷BT[HD-1280P/2.12GB/MP4中字]4k中字已更新

《浴火之路》:人性光辉与生命尊严的较量2024年国庆档,电影市场迎来了一场别开生面的盛宴,其中,《浴火之路》以其独特的题材、精彩的剧情、强大的演员阵容和震撼的视觉呈现,成为了备受瞩目的焦点。该片由五百执导,尚可编剧,肖央、赵丽颖、刘烨等实力派演员主演,是一部聚…

CF582D Number of Binominal Coefficients 题解

第一道没看题解写出来的黑,写了一上午+半下午,算了两页纸,还是太蒻了CF582D Number of Binominal Coefficients 题解 纪念一下自己第一道独立 A 掉的黑题 / CF3300。 题目大意 给定质数 \(p\) 和整数 \(\alpha,A\),求满足 \(0 \le k \le n \le A\) 且 \(p^{\alpha}|\binom …

PbootCms网站如何自动清理runtime缓存

要在 PbootCMS 中实现自动清理 runtime 缓存,可以通过以下步骤进行操作: 步骤 1: 修改 ExtLabelController.php 文件打开文件打开文件:\apps\home\controller\ExtLabelController.php找到 test() 方法找到以下代码:// 测试扩展单个标签 private function test() {$this->…