Vue3之setup方法

Vue 3 的 setup 方法是 Vue Composition API 的一部分,用于组织和复用 Vue 组件的逻辑代码。Vue Composition API 允许您以更具响应性和函数式的方式来组织和复用 Vue 组件中的代码,特别是在处理复杂逻辑或跨组件共享逻辑时非常有用。

以下是关于 setup 方法的一些详细解读:

setup 方法的引入

在 Vue 2.x 版本中,组件的逻辑通常使用 datamethodscomputedwatch 等选项来组织和实现。但在大型或复杂的组件中,随着逻辑的增多,这种方式可能会导致代码变得难以管理和维护。Vue 3 的 setup 方法和 Composition API 的引入就是为了解决这个问题。

setup 方法的用途

setup 方法在组件的生命周期中非常早期被调用,它发生在 beforeCreate 钩子之前,并且在此之后不再存在这两个生命周期钩子。这是因为 setup 方法被设计为用于替代这两个钩子的功能。

setup 方法的主要目的是为组件实例设置 reactive 数据、computed 属性、watch 侦听器以及可复用的方法(函数)。setup 方法还可以接收两个参数:propscontext,这使得您可以在此方法中访问到组件的属性(props)和上下文信息。

setup 方法的使用

setup 方法返回一个对象,该对象包含应该暴露给组件模板的属性、方法等。这意味着您可以在模板中直接访问和使用 setup 方法中返回的任何数据或方法。

setup 方法与组件的关系

setup 方法与组件的关系非常紧密。在组件被创建时,setup 方法会被调用,并用于初始化和配置组件的内部状态和行为。在组件的模板中,您可以直接使用 setup 方法中返回的任何响应式数据或方法。

示例代码

以下是一个使用 setup 方法和 Composition API 的 Vue 3 组件示例:

import { reactive, computed } from 'vue';export default {props: {initialCount: {type: Number,default: 0}},setup(props, context) {// 响应式数据const count = reactive({ value: props.initialCount });// 计算属性const doubledCount = computed(() => count.value * 2);// 方法const increment = () => {count.value++;};// 返回暴露给模板的对象return {count,doubledCount,increment};}
};

setup 方法的内部工作

  1. 接收参数setup 方法可以接收两个参数:propscontextprops 是组件接收的属性,它是一个响应式对象,当属性值变化时,Vue 会自动更新组件。context 是一个包含了组件的上下文信息的对象,例如 attrs、slots、emit 等。

  2. 定义响应式数据和状态:在 setup 方法内部,你可以使用 reactiveref 等函数来定义组件的响应式数据和状态。这些数据和状态可以在组件的模板中直接使用,并且当它们变化时,Vue 会自动更新组件。

  3. 定义计算属性:使用 computed 函数,你可以在 setup 方法内部定义计算属性。计算属性是基于组件的响应式数据派生出来的属性,当依赖的数据变化时,计算属性会自动更新。

  4. 定义方法:在 setup 方法内部,你可以定义组件的方法,这些方法可以在模板中通过事件监听器等方式被调用。

  5. 返回暴露的对象setup 方法最后需要返回一个对象,这个对象包含了需要暴露给组件模板的属性和方法。模板中可以直接使用这些属性和方法。

setup 方法的优点

  1. 更好的代码组织:通过 setup 方法和 Composition API,你可以将组件的逻辑代码按照功能或用途进行分组和封装,使得代码更加清晰和易于维护。

  2. 更好的逻辑复用:使用 Composition API,你可以将可复用的逻辑代码提取出来,以函数的形式进行封装和复用。这使得跨组件共享逻辑变得更加容易和灵活。

  3. 更好的 TypeScript 支持:Composition API 的设计使得它更容易与 TypeScript 集成,从而提供更好的类型检查和代码提示功能。这对于大型或复杂的 Vue 项目来说是非常有用的。

  4. 更灵活的响应式系统:Vue 3 的响应式系统更加灵活和强大,通过 reactiveref 等函数,你可以更方便地创建和管理响应式数据和状态。同时,新的响应式系统也提供了更好的性能优化和内存管理。

注意事项

  1. 不要在 setup 方法中使用 this:在 setup 方法中,this 不再指向 Vue 实例,因此你不能在 setup 方法中使用 this 来访问组件的属性或方法。相反,你应该使用 propscontext 参数来访问这些信息。

  2. setup 方法不能调用生命周期钩子:在 Vue 3 中,setup 方法是一个特殊的生命周期函数,它发生在 beforeCreate 钩子之前。因此,你不能在 setup 方法中直接调用其他生命周期钩子(如 mountedupdated 等)。相反,你应该使用 Composition API 提供的函数(如 onMountedonUpdated 等)来处理这些钩子的逻辑。但是需要注意的是,这些函数不能在 setup 方法外部使用,它们必须被定义在 setup 方法内部并且被返回出去才能在模板中使用。然而这个描述可能有些误导,实际上你可以在 setup 方法内部使用这些生命周期函数(如 onMounted 等),但不需要将它们返回给模板。正确的做法是在 setup 内部直接使用这些函数来注册生命周期钩子。例如:import { onMounted } from 'vue'; onMounted(() => { console.log('Component is mounted'); });。这样当组件挂载完成时,会执行注册的回调函数。

  3. 与 Options API 的关系:虽然 Composition API 提供了更灵活和组织性更好的方式来编写 Vue 组件的逻辑代码,但它并不是要完全取代 Options API(如 datamethodscomputed 等选项)。在一些简单的组件中,使用 Options API 可能仍然是一个更好的选择。你可以根据项目的具体需求和个人的编程风格来选择使用哪种 API。然而实际上在一个组件中你不能同时使用 Options API (如 data, methods) 和 Composition API (如 setup)。如果你选择使用 Composition API,那么所有的响应式数据、计算属性、方法等都应该在 setup 函数中定义并返回。但请注意这个描述可能有些过于绝对,实际上在某些情况下你可以在同一个组件中同时使用 Options API 和 Composition API(通过 setup 方法),但通常不建议这样做因为这可能会导致混淆和难以维护的代码。正确的做法是选择其中一种 API 风格并坚持使用它。

  4. 响应式数据的更新和追踪:在 setup 方法中定义的响应式数据和状态会被 Vue 自动追踪其变化,并且当这些数据变化时,Vue 会自动更新组件。这使得你无需手动调用更新方法或检查数据的变化。但需要注意的是,由于 JavaScript 的限制,某些操作(如直接修改数组或对象的属性)可能不会触发 Vue 的自动更新机制。在这种情况下,你需要使用 Vue 提供的响应式方法来更新数据(如使用 reactiveref 封装的数据的 .value 属性)。

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

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

相关文章

Java NIO详解

一、概念 NIO, 即new io,也叫非阻塞io 二、NIO三个核心组件: Buffer数据缓冲区Channel通道Selector选择器 1、Buffer缓冲区 缓冲区本质上是一个可以存放数据的内存块(类似数组),可以在这里进行数据写入和读取。此…

第十四届省赛大学B组(C/C++) 冶炼金属

题目描述 小蓝有一个神奇的炉子用于将普通金属 O 冶炼成为一种特殊金属 X。这个炉子有一个称作转换率的属性 V,V 是一个正整数,这意味着消耗 V 个普通金属 O 恰好可以冶炼出一个特殊金属 X,当普通金属 O 的数目不足 V 时,无法继续…

【Java】LinkedList模拟实现

目录 整体框架IMyLinkedList接口IndexNotLegalException异常类MyLinkedList类成员变量(节点信息)addFirst(头插)addLast(尾插)在指定位置插入数据判断是否存在移除第一个相等的节点移除所有相等的节点链表的长度打印链表释放回收链表 整体框架 IMyLinkedList接口 这个接口用来…

Leetcode704_二分查找

1.leetcode原题链接:. - 力扣(LeetCode) 2.题目描述 给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标&#xff…

京东云服务器价格_云主机价格查询系统_2024年京东云优惠活动

2024年京东云服务器优惠价格表,轻量云主机优惠价格5.8元1个月、轻量云主机2C2G3M价格50元一年、196元三年,2C4G5M轻量云主机165元一年,4核8G5M云主机880元一年,游戏联机服务器4C16G配置26元1个月、4C32G价格65元1个月、8核32G费用…

OpenHarmony如何模拟搭建本地http静态服务

简介 本文是在基于OpenHarmony 4.0的基础上,介绍了一种编写一个前端http静态服务的思路. 方案设计 在OpenHarmony上,如果想要访问本地网页。有两种方案 u 方案一:使用file协议,将html放至entry/src/main/resource/rawfile下&#…

构建ELK+Filebeat+kafka+zookeeper大数据日志分析平台

主机IP 角色 所属服务层 部署服务 192.168.11.11 日志生产 采集层 filebeat 192.168.11.12 日志缓存 数据处理层、缓存层 Zookeeperkafkalogstash 192.168.11.13 192.168.11.14 日志展示 持久、检索、展示层 Logstashelasticsearchkibana 数据流向 filebeat--…

#设计模式#3.1 抽象工厂

抽象工厂模式是一种创建型设计模式,它提供了一种方式,可以将一组具有同一主题的单独的工厂封装起来。在抽象工厂模式中,抽象工厂定义了产品的创建接口,但是由子类决定实例化哪一个产品类。 在Python中,你可以使用abc模…

维修西格玛泰克触摸屏ETV0551 Sigmatek ETV 0555工业电脑控制面板

控制面板 ETV 0555 控制面板是自动化编程和可视化的智能终端流程。 过程诊断以及操作和监控自动化程序 使用此终端进行简化。触摸屏作为过程数据和参数的输入介质; 输出是显示在 5.7“ VGA TFT 彩色显示屏上。 使用LSE掩模编辑器,可以在PC上创建图形&…

华清远见STM32U5开发板助力2024嵌入式大赛ST赛道智能可穿戴设备及IOT选题项目开发

第七届(2024)全国大学生嵌入式芯片与系统设计竞赛(以下简称“大赛”)已经拉开帷幕,大赛的报名热潮正席卷而来,高校电子电气类相关专业(电子、信息、计算机、自动化、电气、仪科等)全…

新能源充电桩站场AI视频智能分析烟火检测方案及技术特点分析

新能源汽车充电起火的原因多种多样,涉及技术、设备、操作等多个方面。从技术层面来看,新能源汽车的电池管理系统可能存在缺陷,导致电池在充电过程中出现过热、短路等问题,从而引发火灾。在设备方面,充电桩的设计和生产…

若干比赛题目以及补题复盘

一些补题或者比赛中比较典型的问题 1.Problem - E - Codeforces 这道题有这几个点: 1.答案长度只有可能是因数 2.如果一个字符串k是答案,那么这个字符串满足k*xs,差别不大于一,那么这x个字符串中与k不同的至多有一个,所以判断…

Linux部署Kafka2.8.1

安装Jdk 首先确保你的机器上安装了Jdk,Kafka需要Java运行环境,低版本的Kafka还需要Zookeeper,我此次要安装的Kafka版本为2.8.1,已经内置了一个Zookeeper环境,所以我们可以不部署Zookeeper直接使用。 1、解压Jdk包 t…

接口自动化框架搭建(八):pytest+allure+jenkins接入

1,安装allure插件 2,创建jenkins项目 怎么确定路径,可以查看工作空间,jenkins默认根目录就是工作空间 配置执行用例的命令,可以现在pycharm上试一下,然后在jenkins中配置: 把启动java服务的代…

每天五分钟深度学习:使用神经网络完成人脸的特征点检测

本文重点 我们上一节课程中学习了如何利用神经网络对图片中的对象进行定位,也就是通过输出四个参数值bx、by、bℎ和bw给出图片中对象的边界框。 本节课程我们学习特征点的检测,神经网络可以通过输出图片中对象的特征点的(x,y)坐标来实现对目标特征的识别,我们看几个例子。…

162.乐理基础-和声大调、旋律大调

内容参考于: 三分钟音乐社 上一个内容:161.音程、和弦板块总结、重点、建议 首先需要回忆一下18.调式、自然大调式(C大调、D大调。。。)与19.音阶是什么、有什么用,在18.调式、自然大调式(C大调、D大调。…

【php程序开发从入门到精通】——搭建PHP开发环境

👨‍💻个人主页:开发者-曼亿点 👨‍💻 hallo 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍💻 本文由 曼亿点 原创 👨‍💻 收录于专栏&#xff1a…

使用Spark进行数据清洗和存储:从商城数据到HDFS和数据库

摘要:本文介绍了如何使用Spark进行数据清洗和存储的过程。通过结合Spark的强大功能和Java编程知识,我们可以处理商城上报的数据,并将清洗后的数据存储到HDFS和数据库中。本文提供了详细的代码示例,帮助读者理解和实践数据清洗和存…

联通iccid 19转20 使用luhn 算法的计算公式

联通iccid 19转20 使用luhn 算法的计算公式 第一次对接iccid 才知道 使用的是luhn 算法 19转20位 文章来源于 文章来源 当时也是一脸懵逼 的状态,然后各种chatgpt 寻找,怎么找都发现不对,最后看到这片java的文章实验是正确的,因…

服务器被CC攻击之后怎么办?

1.取消域名绑定取消域名绑定后Web服务器的CPU能够马上恢复正常状态,通过IP进行访问连接一切正常。但是不足之处也很明显,取消或者更改域名对于别人的访问带来了不变,另外,对于针对IP的CC攻击它是无效的,就算更换域名攻…