【vue3|第4期】Vue3的选项式与组合式

日期:2024年5月30日
作者:Commas
签名:(ง •_•)ง 积跬步以致千里,积小流以成江海……
注释:如果您觉得有所帮助,帮忙点个赞,也可以关注我,我们一起成长;如果有不对的地方,还望各位大佬不吝赐教,谢谢^ - ^
1.01365 = 37.7834;0.99365 = 0.0255
1.02365 = 1377.4083;0.98365 = 0.0006


文章目录

  • 一、前言
  • 二、 选项式(Options API)
    • (2-1)示例
    • (2-2)选项式的优点
    • (2-3)选项式的缺点
  • 三、 组合式(Composition API)
    • (3-1)示例
      • (3-1-1)组合式 + setup()函数式
      • (3-1-2)组合式 + setup语法糖式
    • (3-2)组合式的优点
    • (3-3)组合式的缺点
  • 四、总结


在这里插入图片描述


一、前言

Vue3,当前前端开发的热门框架,为开发者带来了两种组件编写方式:选项式API组合式API。这些不同的编写方式源于 Vue 的演进,却也带来了困惑,尤其是对新手来说。本文的目标是澄清这些混淆,详细解释两种 API 的关联、差异以及它们各自的适用场景和优势。

二、 选项式(Options API)

选项式API是Vue2中广为人知的方式,它通过预定义的选项如datamethodscomputed等来组织代码。每个选项负责组件的不同方面,这样可以让代码结构清晰,易于理解和维护。

(2-1)示例

<template>
  <div>
    <button @click="increment">Increment</button>
    <p>Count: {{ count }}</p>
  </div>
</template>

<script>
export default {
  data() {
    return {
      count: 0
    };
  },
  methods: {
    increment() {
      this.count++;
    }
  }
};
</script>

解析与说明:

  1. <template> 这是Vue模板的部分,它定义了组件的HTML结构。在这个例子中,我们有一个按钮和一个段落(<p>标签),按钮用来增加计数,段落用来显示当前计数。
  2. <script> 这是Vue组件的脚本部分,它使用JavaScript编写。在这个例子中,我们导出了一个默认的Vue组件对象。
  3. export default {...} 这是使用Vue 3的export default语法来定义一个组件。在这个对象中,我们定义了组件的属性和方法。
  4. data() {...} data函数返回一个对象,这个对象包含了组件的响应式数据。在这个例子中,我们定义了一个名为count的属性,它的初始值是0。
  5. methods: {...} methods对象包含了组件的方法。在这个例子中,我们定义了一个名为increment的方法,当按钮被点击时,它会增加count的值。
  6. @click指令: 这是Vue的一个自定义指令,用来绑定事件监听器。在这个例子中,当按钮被点击时,increment方法会被调用。
  7. {{ count }} 这些是Vue的插值表达式,它们用来将数据绑定到模板字符串中。当count属性改变时,插值表达式所在的位置也会相应更新。

(2-2)选项式的优点

  1. 易于理解和上手:对于新手来说,选项式API的结构更加直观,容易理解。
  2. 代码组织结构清晰:不同的选项负责不同的功能,使得代码结构清晰,易于阅读和维护。
  3. 兼容性:对于Vue2迁移到Vue3的项目,可以更方便地逐步迁移。

(2-3)选项式的缺点

  1. 逻辑分散:同一个功能逻辑可能会分散在不同的选项中,导致代码分散,不易维护。
  2. 代码冗余:对于有多个组件共享相同逻辑的情况,需要重复编写相同的代码,导致代码冗余。
  3. 类型支持不友好:对于TypeScript用户来说,选项式API的类型支持不如组合式API。

三、 组合式(Composition API)

组合式API是Vue3引入的一种新的编写方式,它通过setup函数将组件的逻辑组织在一起。这样可以将相关的逻辑放在一起,避免了选项式API中的逻辑分散问题。

(3-1)示例

组合式分两种:

1、组合式 + setup()函数式
2、组合式 + setup语法糖式(即 <script setup>模式 )。

(3-1-1)组合式 + setup()函数式

<template>
  <div>
    <button @click="increment">Increment</button>
    <p>Count: {{ count }}</p>
  </div>
</template>
<script>
import { ref, onMounted } from 'vue';
export default {
  setup() {
    // 使用ref函数创建一个响应式引用,相当于Vue 2中的data属性
    const count = ref(0);
    // 使用一个方法来更新count的值
    function increment() {
      count.value++;
    }
    // 使用onMounted生命周期钩子来处理组件挂载后的逻辑
    onMounted(() => {
      console.log('Component is mounted!');
    });
    // 返回在模板中需要使用的数据和方法
    return {
      count,
      increment
    };
  }
};
</script>

解析与说明:

  1. import { ref, onMounted } from 'vue' 这行代码从Vue 3的vue包中导入了refonMounted两个函数。ref用于创建响应式引用,onMounted是一个生命周期钩子,它在组件挂载后执行。
  2. export default {...} 仍然使用export default来定义组件。
  3. setup()函数: 这是Vue 3中引入的新函数,它是组合式API的入口。在setup()函数中,你可以定义响应式变量、计算属性、侦听器等。
  4. const count = ref(0) 使用ref函数创建了一个响应式引用,它相当于Vue 2中的data属性。count现在是响应式的,当它在组件内部改变时,界面上的插值表达式会自动更新。
  5. function increment() {...} 定义了一个方法来更新count的值。
  6. onMounted(() => {...}) 使用onMounted生命周期钩子来处理组件挂载后的逻辑,例如在控制台打印消息。
  7. 返回对象: setup()函数返回一个对象,其中包含了在模板中需要使用的数据和方法。这些数据和方法可以通过this在模板中访问,但在setup()函数内部,你不需要使用this来引用它们。

(3-1-2)组合式 + setup语法糖式

<template>
  <div>
    <button @click="increment">Increment</button>
    <p>Count: {{ count }}</p>
  </div>
</template>
<script setup>
import { ref, onMounted } from 'vue';
// 响应式变量
const count = ref(0);
// 方法
function increment() {
  count.value++;
}
// 生命周期钩子
onMounted(() => {
  console.log('Component is mounted!');
});
</script>

解析与说明:

  1. <script setup>标签: 这是Vue 3引入的新标签,用于定义组合式API的脚本部分。在这个标签内部,你可以使用importconstfunction等JavaScript语法来定义组件的响应式状态和方法。
  2. import { ref, onMounted } from 'vue' 这行代码从Vue 3的vue包中导入了refonMounted两个函数。
  3. const count = ref(0) 使用ref函数创建了一个响应式引用,相当于选项式API中的data属性。
  4. function increment() {...} 定义了一个方法来更新count的值。
  5. onMounted(() => {...}) 使用onMounted生命周期钩子来处理组件挂载后的逻辑。
  6. 返回对象:<script setup>模式中,你不需要显式返回响应式数据和方法,因为它们可以直接在模板中使用。

(3-2)组合式的优点

  1. 逻辑集中:通过setup函数,可以将组件的所有逻辑放在一起,使得代码更加集中,易于维护。
  2. 更好的类型支持:对于TypeScript用户来说,组合式API提供了更好的类型支持。
  3. 代码复用:通过自定义函数或钩子,可以方便地实现代码复用。

(3-3)组合式的缺点

  1. 学习成本:对于新手来说,组合式API可能需要一定的时间来适应。
  2. 重构成本:对于已有的项目,如果采用选项式API,那么重构为组合式API可能需要一定的成本。

四、总结

Vue3选项式API组合式API各有优缺点,开发者可以根据自己的需求选择合适的方式。

对于新手或小型项目,选项式API可能更适合;而对于大型项目或需要更好的类型支持的项目,组合式API可能是更好的选择。同时,组合式API的两种写法也为我们提供了更多的选择,可以根据项目需求灵活运用。

在未来的发展趋势中,组合式API可能会越来越受到开发者的青睐,因为它提供了更高的灵活性和更好的类型支持。但无论如何,Vue3为我们提供了两种方式,让我们可以根据项目需求灵活选择,这也是Vue3如此受欢迎的原因之一。


参考文章:

  • Vue.js

版权声明:本文为博主原创文章,如需转载,请给出:
原文链接:https://blog.csdn.net/qq_35844043/article/details/139321504

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

解析前端开发中同源策略与配置代理

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、pandas是什么&#xff1f;二、使用步骤 1.引入库2.读入数据总结 前言 在前端开发中&#xff0c;跨域请求是一个常见的问题。同源策略限制了浏览器中一个页面…

win10系统下WPS工具显示灰色全部用不了,提示登录

如果你在写文档或使用excel时发现导航栏的工具全部使用不了&#xff0c;弹出是需要您登录&#xff0c;可以通过以下操作不用登录。 按照 1&#xff08;搜索框&#xff09;—> 2&#xff08;应用&#xff09;—> 3&#xff08;WPS Office&#xff09;点鼠标左键—> 4&a…

使用LeanCloud平台的即时通讯

LeanCloud 是领先的 Serverless 云服务&#xff0c;为产品开发提供强有力的后端支持&#xff0c;旨在帮助开发者降低研发、运营维护等阶段投入的精力和成本。 LeanCloud 整合了各项服务&#xff0c;让开发者能够聚焦在核心业务上&#xff0c;为客户创造更多价值。 *即时通讯 …

PromptIR论文阅读笔记

MZUAI和IIAI在NIPS2023上的一篇论文&#xff0c;用prompt来编码degradation&#xff0c;然后用来guide restoration network&#xff0c;使得模型能够泛化到不同degradation types and levels&#xff0c;也就是说是一个模型一次训练能够应对多种degradation的unified model。文…

apache大数据各组件部署搭建(超级详细)

apache大数据数仓各组件部署搭建 第一章 环境准备 1. 机器规划 准备3台服务器用于集群部署,系统建议CentOS7+,2核8G内存 172.19.195.228 hadoop101 172.19.195.229 hadoop102 172.19.195.230 hadoop103 [root@hadoop101 ~]# cat /etc/redhat-release CentOS Linux rele…

Azure DevOps Server 2022.2(升级过程)

1. 概述 2. 前期准备3. 升级过程4. 验证成果 1. 概述 本月微软公司发布了Azure DevOps Server 2022的第二个升级包Update 2 https://learn.microsoft.com/en-us/azure/devops/server/release-notes/azuredevops2022u2。 自2024年3月12日发布Azure DevOps Server 2022 Update 1(…

Linux综合实践(Ubuntu)

目录 一、配置任务 1.1 配置该服务器的软件源为中科大软件源 1.2 安装相关软件openssh-server和vim 1.3 设置双网卡&#xff0c;网卡1为NAT模式&#xff0c;网卡2为桥接模式(桥接模式下&#xff0c;使用静态ip&#xff0c;该网卡数据跟实验室主机网络设置相似&#xff0c;除…

Jvm(一)之栈、堆、方法区

前言-与正文无关 生活远不止眼前的苦劳与奔波&#xff0c;它还充满了无数值得我们去体验和珍惜的美好事物。在这个快节奏的世界中&#xff0c;我们往往容易陷入工作的漩涡&#xff0c;忘记了停下脚步&#xff0c;感受周围的世界。让我们一起提醒自己&#xff0c;要适时放慢脚步…

中文多模态InternVL-Chat-V1-5,中文理解能力强劲,8 项指标超越商业模型,性能媲美 GPT-4V

前言 近年来&#xff0c;多模态大型语言模型&#xff08;MLLM&#xff09;的快速发展&#xff0c;为人工智能在图像、文本等多模态信息理解和处理方面带来了前所未有的突破。然而&#xff0c;现有的主流多模态模型多以英文为训练语言&#xff0c;在中文理解和处理方面存在着明…

SwiftUI中Popover的使用(弹出方式,箭头位置,如何退出)

在iOS中&#xff0c;popover是出现在现有内容顶部的UI元素&#xff0c;通常用于在上下文中向用户呈现新视图。与其他占用整个屏幕的视图控制器不同&#xff0c;popover出现在一个较小的、集中的区域&#xff0c;从而使用户能够在必要时与popover外的应用程序的其他部分进行交互…

521源码-游戏源码-2024卡牌回合自走棋手游《梦间集》推出全新Linux手工服务端

首款稀有卡牌回合自走棋手游《梦间集》推出全新Linux手工服务端整理 更多网站源码&#xff0c;游戏源码&#xff0c;学习教程&#xff0c;请点击&#x1f449;-521源码-&#x1f448;获取最新资源 本游戏下载地址&#xff1a;2024卡牌回合自走棋手游《梦间集》推出全新Linux手…

算法(十三)回溯算法---N皇后问题

文章目录 算法概念经典例子 - N皇后问题什么是N皇后问题&#xff1f;实现思路 算法概念 回溯算法是类似枚举的深度优先搜索尝试过程&#xff0c;主要是再搜索尝试中寻找问题的解&#xff0c;当发生不满足求解条件时&#xff0c;就会”回溯“返回&#xff08;也就是递归返回&am…

switch语句

作用 让顺序执行的代码&#xff0c;产生分支。 基本语法 switch(变量) {//变量 常量 执行 case和 break之间的代码case 常量:满足条件执行的代码逻辑;break;case 常量:满足条件执行的代码逻辑;break;//case 可以有无数个default://如果上面case的条件都不满足 就会执行 def…

sqlite--SQL语句进阶

SQL语句进阶 函数和聚合 函数&#xff1a; SQL 语句支持利用函数来处理数据&#xff0c; 函数一般是在数据上执行的&#xff0c; 它给数据的转换和处理提供了方便常用的文本处理函数&#xff1a; 常用的文本处理函数&#xff1a; // 返回字符串的长度 length();//将字符串…

【阿里云】在云服务器ECS 安装MySQL、本地远程连接或宝塔连接(手动部署)

目录 一、安装MySQL 二、配置MySQL 三、远程访问MySQL数据库 四、Navicat本地连接远程MySQL 五、宝塔连接MySQL 如果你是使用宝塔安装的MySQL请绕过&#xff0c;以下是通过命令行模式&#xff08;手动部署&#xff09;进行安装、配置及运行。 安装&#xff1a;MySQL8.0 …

C#WPF数字大屏项目实战02--主窗体布局

1、主窗体起始属性 设置有关属性如下&#xff1a; WindowStyle"None"-》无边框 AllowsTransparency"True" -》允许透明 WindowStartupLocation"CenterScreen"-》启动时位于屏幕中间 FontFamily"Microsoft YaHei"-》字体微软雅黑 …

更新mirh connect 内置derby数据库密码

更新mirh connect 内置derby数据库密码 1、下载derby连接客户端 https://archive.apache.org/dist/db/derby/ 选择任意版本即可&#xff0c;比如 https://archive.apache.org/dist/db/derby/db-derby-10.14.2.0/db-derby-10.14.2.0-bin.zip 2、连接mirh文件数据库 1、把mi…

Linux主机安全可视化运维(免费方案)

本文介绍如何使用免费的主机安全软件,在自有机房或企业网络实现对Linux系统进行可视化“主机安全”管理。 一、适用对象 本文适用于个人或企业内的Linux服务器运维场景,实现免费、高效、可视化的主机安全管理。提前发现主机存在的安全风险,全方位实时监控主机运行时入侵事…

单片机原理及应用复习

单片机原理及应用 第二章 在AT89S52单片机中&#xff0c;如果采用6MHz晶振&#xff0c;一个机器周期为 2us 。 时钟周期Tocs1focs 机器周期 Tcy12focs 指令周期&#xff1a;一条指令所用的时间&#xff0c;单字和双字节指令一般为单机器周期和双机器周期。 AT89S5…

深色系的B端界面,特定场景非常适合。

深色系B端界面有以下几个好处&#xff1a; 提供更好的可读性&#xff1a;深色背景可以提供更高的对比度&#xff0c;使文字和图标更加清晰易读&#xff0c;尤其在低光环境下或者长时间使用的情况下&#xff0c;可以减少眼睛的疲劳。强调重要内容&#xff1a;深色背景可以使重要…