vue3 setup基本使用

1. 基本概念

在 Vue 3 中,setup 函数是在组件创建之前调用的,用于初始化组件的响应式数据、计算属性、方法等。setup 函数返回的对象会作为组件的上下文提供给模板,模板中可以直接访问返回的属性和方法。

<template><div><p>{{ message }}</p><button @click="increment">Increment</button></div>
</template><script>
import { ref } from 'vue';export default {setup() {// 响应式数据const message = ref('Hello, Vue 3!');const count = ref(0);// 方法const increment = () => {count.value++;};// 返回的数据和方法将暴露给模板return {message,count,increment};}
}
</script>

二 特点

  • setup函数返回的对象中的内容,可直接在模板中使用。
  • setup中访问thisundefined

函数作用域

在 setup 中,你不再使用 this 来访问组件实例的属性和方法。setup 函数的设计理念是使函数逻辑更加清晰和集中,而不依赖于 this。
组合式 API 的设计

组合式 API 强调通过显式传递参数和返回值来管理组件状态和行为,而不是通过 this 访问实例属性。这样可以提高逻辑的可读性和复用性。

  • setup 函数在组件实例创建之前执行,最早在生命周期钩子之前被调用。这使得你可以在组件实例化之前进行初始化操作。

三 setup 与 Options API 的关系

setup 是 Vue 3 引入的组合式 API 的核心部分,而 Options API 是 Vue 2 中的传统方式。两者的关系如下:

  • Vue2 的配置(datamethos…)中可以访问到 setup中的属性、方法。
  • 但在setup不能访问到Vue2的配置(datamethos…)。
  • 如果与Vue2冲突,则setup优先。

四 setup 语法糖

setup函数有一个语法糖,这个语法糖,可以让我们把setup独立出去,代码如下:

<template><button @click="handleClick">Click me</button><p>Count: {{ count }}</p>
</template><script setup>
import { ref } from 'vue';// 直接在这里定义响应式数据和方法
const count = ref(0);const handleClick = () => {count.value++;
};
</script>

主要特点:

  • 简化语法:不需要显式定义 setup 函数,直接在 <script setup> 中编写逻辑。
  • 自动引入:常用的 Vue 功能(如 ref、computed)自动引入,无需手动导入。
  • 更清晰的代码结构:让组件逻辑和模板结构更加直观和简洁。

五 注意点

  1. 响应式数据

在 setup 中创建响应式数据时,需要使用 Vue 3 提供的 ref 和 reactive API。

ref:用于创建基本类型的响应式数据(如字符串、数字、布尔值等)。

import { ref } from 'vue';const count = ref(0); // 创建一个响应式的基本数据

reactive:用于创建对象和数组的响应式数据。

import { reactive } from 'vue';const state = reactive({count: 0,message: 'Hello, Vue!'
});
  1. 返回值
    setup 函数必须返回一个对象,这个对象中的属性和方法会暴露给组件的模板部分。返回的对象中的数据和方法可以直接在模板中使用。
import { ref } from 'vue';export default {setup() {const count = ref(0);const increment = () => {count.value++;};return {count,increment};}
};
模板部分:<template><button @click="increment">Increment</button><p>{{ count }}</p>
</template>
  1. 生命周期钩子

在 setup 中,可以使用 Vue 3 提供的生命周期钩子函数来替代 Vue 2 的生命周期选项。

onMounted:组件挂载完成后调用。

import { onMounted } from 'vue';onMounted(() => {console.log('Component is mounted.');
});

onUnmounted:组件卸载时调用。

import { onUnmounted } from 'vue';onUnmounted(() => {console.log('Component is unmounted.');
});
  1. 上下文

setup 函数的第二个参数是 context 对象,它包含以下属性:

  • attrs:包含组件的非 props 属性(如 v-bind 绑定的属性)。
  • slots:包含插槽的内容。
  • emit:用于触发事件。
export default {setup(props, context) {const { emit } = context;const handleClick = () => {emit('custom-event', 'payload');};return {handleClick};}
};
  1. 函数和变量的作用域
    在 setup 中定义的函数和变量是局部的,只在 setup 内部可见。要让模板或其他函数访问这些定义,必须从 setup 中返回它们。
export default {setup() {const count = ref(0);const increment = () => {count.value++;};return {count,increment};}
};
  1. 异步操作
    在 setup 中处理异步操作时,确保正确管理其生命周期。通常需要结合生命周期钩子(如 onMounted)来处理异步数据请求,避免内存泄漏。
import { ref, onMounted } from 'vue';export default {setup() {const data = ref(null);onMounted(async () => {data.value = await fetchData();});return {data};}
};
  1. this 的使用
    在 setup 中不使用 this,所有的数据和方法都是通过返回的对象或函数调用进行访问。this 仅在 Options API 中有效。
// Options API
export default {data() {return {count: 0};},methods: {increment() {this.count++;}}
};// Composition API
export default {setup() {const count = ref(0);const increment = () => {count.value++;};return {count,increment};}
};
  1. TypeScript 支持
    setup 函数可以与 TypeScript 结合使用,提供类型检查和代码补全。
import { ref } from 'vue';export default {setup() {const count = ref<number>(0);const increment = () => {count.value++;};return {count,increment};}
};

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

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

相关文章

【python学习】-在条件分支结构中错误使用or导致其他条件分支的代码跳过并不执行

在条件分支结构中错误使用or导致其他条件分支的代码跳过并不执行 bug的来源背景代码目标第一版代码第二版代码第三版代码 问题总结后语 bug的来源背景 由于课题更换的原因&#xff0c;最近去做实验搬砖工了&#xff0c;所以大半年没有写代码&#xff0c;这两天开始处理一些代码…

使用CMake组织构建QT项目

文章目录 定位Qt安装路径查找QT包设置自动MOC、UIC和RCC包含和链接Qt库处理资源文件调整编译器设置处理UI文件多平台支持高级编译选项在使用CMake来组织和构建Qt项目时,需要注意一系列的细节以确保项目的顺利编译和运行。这些细节涉及确保Qt和CMake之间的兼容性、处理UI文件和…

HTML详解

1. 文档结构标签 <!DOCTYPE html>&#xff1a;声明文档类型&#xff0c;告诉浏览器这是一个HTML5文档。<html>&#xff1a;HTML文档的根元素&#xff0c;包含整个HTML文档。<head>&#xff1a;包含文档的元数据&#xff08;metadata&#xff09;&#xff0c…

计算多图的等价无向图的邻接链表表示

计算多图的等价无向图的邻接链表表示 摘要:一、引言二、算法思路三、伪代码实现四、C代码实现五、算法分析六、结论摘要: 在图论中,多图(Multigraph)是一种允许边重复以及存在自循环边(即一个顶点到其自身的边)的图。给定一个多图的邻接链表表示,本文旨在探讨如何构造…

Git 忽略已经提交的文件

对于未提交过的文件直接用ignore文件即可,不再赘述 对于已经提交过的文件,但是实际上不需要的,可以用git rm --cached命令 比如下图这个 .vsconfig被我误提交了或者忘了在ignore里添加了 但是我实际上不想要这个文件,那么在项目根目录打开git bash ,输入 git rm --cached .vsc…

【QNX+Android虚拟化方案】107 - QNX NFS Server + Android NFS Client 完整配置

【QNX+Android虚拟化方案】107 - QNX NFS Server + Android NFS Client 完整配置 一、QNX 侧 NFS Server 修改:ip 为 192.168.1.21.1 配置拷贝 nfsd、rpcbind 到 /mnt 目录下1.2 配置 exports1.3 为NFS 共享目录挂载镜像1.4 修 startup.sh 开机自启动 nfsd Server1.5 关闭 QNX…

分歧时间估计与被子植物的年代-文献精读43

Ad fontes: divergence-time estimation and the age of angiosperms 回归本源&#xff1a;分歧时间估计与被子植物的年代 摘要 准确的分歧时间对于解释和理解谱系演化的背景至关重要。在过去的几十年里&#xff0c;有关冠被子植物推测的分子年龄&#xff08;通常估计为晚侏罗…

RabbitMQ中的死信交换机?(RabbitMQ延迟队列有了解过吗)

延迟队列 延迟队列:进入队列的消息会被延迟消费的队列。 延迟队列死信交换机 TTL&#xff08;过期时间&#xff09; 延迟队列的使用场景:超时订单、限时优惠、定时发布 死信交换机 当一个队列中的消息满足下列情况之一时&#xff0c;可以成为死信(dead letter): 消费者使…

wpf prism 《1》、区域 、模块化

安装prism.DryIoc 修改app.xaml <prism:PrismApplication x:Class"WpfApp3.App"xmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x"http://schemas.microsoft.com/winfx/2006/xaml"xmlns:local"clr-namespace:W…

求职Leetcode题目(9)

1.通配符匹配 题解&#xff1a; 其中&#xff0c;横轴为string s&#xff0c;纵轴为pattern p 这个表第(m,n)个格子的意义是:【p从0位置到m位置】这一整段&#xff0c;是否能与【s从0位置到n位置】这一整段匹配 也就是说&#xff0c;如果表格的下面这一个位置储存的是T(True)…

shell脚本--正则表达式

一、正则表达式的类型 在Linux中,有两种流行的正则表达式引擎: POSIX基础正则表达式(basic regular expression,BRE)引擎 POSIX扩展正则表达式(extended regular expression,ERE)引擎 POSIX BRE引擎通常出现在依赖正则表达式进行文本过滤的编程语言中。它为常见模式提供…

pytorch交叉熵损失函数

nn.CrossEntropyLoss 是 PyTorch 中非常常用的损失函数,特别适用于分类任务。它结合了 nn.LogSoftmax 和 nn.NLLLoss(负对数似然损失)的功能,可以直接处理未经过 softmax 的 logits 输出,计算预测值与真实标签之间的交叉熵损失。 1. 交叉熵损失的原理 交叉熵损失衡量的是…

cnocr 安装

打开终端 如果不会打开终端 -> 终端打开输入 pip install cnocr 执行中途可能报错 去这里下载工具&#xff1a;c构建工具下载完打开&#xff0c;勾选这个 然后点安装安装完回到第2步重新执行

等保2.0--安全计算环境--TiDB数据库

在使用本博客提供的学习笔记及相关内容时,请注意以下免责声明:信息准确性:本博客的内容是基于作者的个人理解和经验,尽力确保信息的准确性和时效性,但不保证所有信息都完全正确或最新。非专业建议:博客中的内容仅供参考,不能替代专业人士的意见和建议。在做出任何重要决…

移动端前端开发主流框架及其技术方案

移动端前端开发主流框架及其技术方案 在现代移动端应用开发中&#xff0c;前端框架的选择至关重要。它不仅影响开发效率&#xff0c;还直接关系到应用的性能和用户体验。以下是当前主流的移动端前端框架的详细技术方案&#xff0c;包括 React Native、Flutter 和 Ionic&#x…

PyTorch 的自动求导与计算图

在深度学习中&#xff0c;模型的训练过程本质上是通过梯度下降算法不断优化损失函数。为了高效地计算梯度&#xff0c;PyTorch 提供了强大的自动求导机制&#xff0c;这一机制依赖于“计算图”&#xff08;Computational Graph&#xff09;的概念。 1. 什么是计算图&#xff1…

前胡基因组与伞形科香豆素的进化-文献精读42

The gradual establishment of complex coumarin biosynthetic pathway in Apiaceae 伞形科中复杂香豆素生物合成途径的逐步建立 羌活基因组--文献精读-36 摘要&#xff1a;复杂香豆素&#xff08;CCs&#xff09;是伞形科植物中的特征性代谢产物&#xff0c;具有重要的药用价…

深度学习与大模型第1课环境搭建

深度学习与大模型第1课 环境搭建 1. 安装 Anaconda 首先&#xff0c;您需要安装 Anaconda&#xff0c;这是一个开源的 Python 发行版&#xff0c;能够简化包管理和环境管理。以下是下载链接及提取码&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1Na2xOFpBXQMgzXA…

网络准入控制系统

当我们谈论网络准入控制系统时&#xff0c;我们谈论的并不是网络准入控制系统&#xff0c;而是安全&#xff0c;我们不能只囿于它表面的浮华而忘掉它的本质&#xff0c;记住&#xff0c;不管讨论什么&#xff0c;我们必须要有直达本质的能力。网络的本质就是安全。 网络准入控制…

TDesign 微信小程序组件库配置

文章目录 1.安装 npm 包2. 构建 npm3. 构建完成后即可使用 npm 包。4.修改 app.json5.修改 tsconfig.json6.使用组件 1.安装 npm 包 在小程序 package.json 所在的目录中执行命令安装 npm 包&#xff1a; npm install结果报错 PS C:\WeChatProjects\miniprogram-1> npm i…