活用 Composition API 核心函数,打造卓越应用(上)

news2024/12/29 10:45:33

在这里插入图片描述

🤍 前端开发工程师、技术日更博主、已过CET6
🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1
🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》
🍚 蓝桥云课签约作者、上架课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》

文章目录

  • 一、引言
    • 对 Composition API 的简单介绍
  • 二、核心函数概述
    • 列出 Composition API 中的核心函数
    • 对每个核心函数的作用进行简要说明
  • 三、具体核心函数讲解
    • 详细讲解每个核心函数的语法和参数
    • 提供具体的代码示例来演示函数的使用

一、引言

对 Composition API 的简单介绍

Composition API 是 Vue.js 提供的一种新的代码组织方式,它允许开发者更灵活地组合和复用组件的功能。相比于传统的 Options API,Composition API 采用了更具模块化和函数式的风格。

通过 Composition API,开发者可以使用一组核心函数(如 setuprefreactive 等)来管理组件的状态、响应式数据以及逻辑。这种方式使得代码更加简洁、易读,并且更容易进行测试和维护。

此外,Composition API 还提供了更好的代码分离和可复用性。组件的功能可以分解为独立的函数或模块,然后在需要的地方进行组合和使用。这有助于提高代码的可扩展性和复用性,使开发更加高效。

总的来说,Composition API 为 Vue.js 开发者提供了一种更强大、灵活的方式来构建复杂的用户界面,同时也提升了代码的质量和可维护性。🚀💻

二、核心函数概述

列出 Composition API 中的核心函数

Composition API 中的核心函数有 setuprefreactive

其中,setup 函数是 Composition API 的入口,它在组件的生命周期中尽早执行,即在组件的属性解析之后,但在任何其他生命周期钩子之前。在这个函数中,你可以定义响应式的状态、计算属性、方法和生命周期钩子。

ref 用于基本类型,而 reactive 适用于对象和数组。这两个 API 都返回一个响应式的引用,使得状态的改变能够自动反映到视图上。

对每个核心函数的作用进行简要说明

以下是 Composition API 中核心函数的作用简要说明:

  • setup:是所有 Composition API 的入口,在组件中所用到的:数据、方法等,均要配置在 setup 中。setup 函数有两种返回值,若返回一个对象,则对象中的属性、方法,在模板中均可以直接使用;若返回一个渲染函数,则可以自定义渲染内容。
  • ref:用于创建一个包装对象,将普通的数据变成响应式数据。使用 ref 包装后,你需要通过 .value 来访问和修改数据。
  • reactive:用于创建一个包装对象,可以将整个对象变成响应式。reactive 可以让整个对象变成响应式,所以你可以直接访问和修改对象的属性。

这些函数在 Vue 3的 Composition API 中广泛用于创建和管理响应式数据,有助于更灵活地处理组件内的数据状态。

三、具体核心函数讲解

详细讲解每个核心函数的语法和参数

以下是 Composition API 中核心函数的详细语法和参数:

  • setup 函数:
    • 语法:setup(props, context)setup(props, { attrs, slots, emit })
    • 参数说明:
      • props:包含 props 配置声明且传入了的所有属性的对象。
      • context:一个上下文对象,包含组件的一些上下文信息,如 attrsslotsemit
      • attrs:包含没有在 props 配置中声明的属性的对象,相当于 this.$attrs
      • slots:包含所有传入的插槽内容的对象,相当于 this.$slots
      • emit:一个事件发射器对象,可以用来触发自定义事件。
  • ref 函数:
    • 语法:const xxx = ref(initValue)
    • 参数说明:xxx 是一个变量名,用于存储响应式数据,initValue 是初始值,可以是基本类型或对象类型的数据。
  • reactive 函数:
    • 语法:reactive(obj)
    • 参数说明:obj 是一个普通对象,通过 reactive 函数处理后,该对象会变成响应式对象。

上述内容仅为核心函数的语法和参数说明,具体使用方法和示例请参考 Vue 官方文档。

提供具体的代码示例来演示函数的使用

以下是 Composition API 中核心函数的具体代码示例:

  • setup 函数:
import { Reactive, onMounted } from 'vue';
// 定义响应式状态
export function useUserAuthentication() {
  const state = Reactive({
    user: null,
    error: null,
    loading: false,
  });
  // 异步函数用于认证用户
  const authenticateUser = async (username, password) => {
    state.loading = true;
    try {
      const response = await fetch('/api/authenticate', {
        method: 'POST',
        body: JSON.stringify({ username, password }),
        headers: {
          'Content-Type': 'application/json',
        },
      });
      const userData = await response.json();
      state.user = userData;
    } catch (error) {
      state.error = error;
    } finally {
      state.loading = false;
    }
  };
  // 在组件挂载时自动尝试获取用户信息
  onMounted(() => {
    // 可以在组件挂载时自动尝试获取用户信息
  });
  return {
    ...state,
    authenticateUser,
  };
}
  • ref 函数:
import { ref } from 'vue';
// 定义一个响应式状态变量
const count = ref(0);
// 更改状态、触发更新的函数
function increment() {
  count.value++;
}
// 在组件挂载完毕后,输出计数器的初始值
onMounted(() => {
  console.log(`计数器初始值为 ${count.value}`);
})
  • reactive 函数:
import { Reactive } from 'vue';
// 创建响应式对象
const obj = Reactive({
  data: null,
});
// 监听属性变化
watchEffect(() => {
  console.log(`data 属性的值为: ${obj.data}`);
});

上述代码示例分别展示了 setuprefreactive 函数的基本用法,你可以根据自己的需求进行适当的修改和扩展。

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

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

相关文章

电容充电速度

对电容充电的过程中,电容器充电的电压为,求电容器的充电速度。

相机图像质量研究(22)常见问题总结:CMOS期间对成像的影响--光学串扰

系列文章目录 相机图像质量研究(1)Camera成像流程介绍 相机图像质量研究(2)ISP专用平台调优介绍 相机图像质量研究(3)图像质量测试介绍 相机图像质量研究(4)常见问题总结:光学结构对成像的影响--焦距 相机图像质量研究(5)常见问题总结:光学结构对成…

政安晨:【示例演绎】【Python】【Numpy数据处理】快速入门(三)—— 数组的操作

准备 这是Numpy数据处理的示例演绎系列文章的第三篇,我的前两篇文章为: 政安晨:【示例演绎】【Python】【Numpy数据处理】快速入门(一)https://blog.csdn.net/snowdenkeke/article/details/136125773 政安晨&#x…

挑战杯 python的搜索引擎系统设计与实现

0 前言 🔥 优质竞赛项目系列,今天要分享的是 🚩 python的搜索引擎系统设计与实现 🥇学长这里给一个题目综合评分(每项满分5分) 难度系数:3分工作量:5分创新点:3分 该项目较为新颖&#xff…

心理辅导|高校心理教育辅导系统|基于Springboot的高校心理教育辅导系统设计与实现(源码+数据库+文档)

高校心理教育辅导系统目录 目录 基于Springboot的高校心理教育辅导系统设计与实现 一、前言 二、系统功能设计 三、系统实现 1、学生功能模块的实现 (1)学生登录界面 (2)留言反馈界面 (3)试卷列表界…

娱乐直播APP开发:引领潮流,创新无界

随着互联网技术的飞速发展,娱乐直播APP已经成为现代人生活的重要组成部分。它以其独特的互动性、即时性和个性化,吸引了大量用户。本文将深入探讨娱乐直播APP开发的关键要素,以及如何在这个竞争激烈的市场中脱颖而出。 一、娱乐直播APP的核心…

http“超级应用与理解”

本篇文章来介绍一下http协议和其应用 1.http协议是在OSI模型的哪一层 HTTP(超文本传输协议)是应用层协议,它是在 OSI 模型的最高层,即第七层——应用层。HTTP 通过互联网来传输数据和信息,主要用于 Web 浏览器和 Web …

关于DVWA靶场Command Injection(命令注入)乱码的解决方案

乱码如下图: 出现乱码一般都是编码方式的问题,我们只需要对其换一种编码方式输出即可 靶场在 WWW 目录下,在靶场所在路径下有一个 dvwa 文件夹 进入之后找到 includes 文件夹 进入找到文件 dvwaPage.inc.php 右键,使用记事本打开…

ZYNQ:PL-CAN总线功能应用

流程背景 前期基本实现PS端的CAN总线功能,现阶段的主要目的是实现PL端的CAN总线功能,需要采用CAN IP。 PL系统搭建 PL外设时钟源 搭建完vivado系统后,需要在sdk编程。但是在配置PL-CAN时,意识到CAN时钟值不清楚&…

【NLP】MHA、MQA、GQA机制的区别

Note LLama2的注意力机制使用了GQA。三种机制的图如下: MHA机制(Multi-head Attention) MHA(Multi-head Attention)是标准的多头注意力机制,包含h个Query、Key 和 Value 矩阵。所有注意力头的 Key 和 V…

铱塔 (iita) 开源 IoT 物联网开发平台,基于 SpringBoot + TDEngine +Vue3

01 铱塔 (iita) 物联网平台 铱塔智联 (open-iita) 基于Java语言的开源物联网基础开发平台,提供了物联网及相关业务开发的常见基础功能, 能帮助你快速搭建自己的物联网相关业务平台。 铱塔智联平台包含了品类、物模型、消息转换、通讯组件(mqtt/EMQX通讯组…

第7章 Page449~451 7.8.9智能指针 std::shared_ptr

“shared_ptr”是“共享式智能指针”。 即多个“shared_ptr”之间可以管理同一个裸指针。于是 O* o new O; //一个裸指针 std::shared_ptr <O> p1(o); //交给p1管 std::shared_ptr <O> p2(o); //又交给p2管 出乎意料&#xff0c;以上代码仍然是可以通过编译但运…

云计算基础-大页内存

大页内存功能概述 什么是大页内存 简单来说&#xff0c;就是通过增大操作系统页的大小来减小页表&#xff0c;从而避免快表缺失 主要应用场景 主要运用于内存密集型业务的虚拟机&#xff0c;比如对于运行数据库系统的虚拟机&#xff0c;采用HugePages(大页)后&#xff0c;可…

《区块链公链数据分析简易速速上手小册》第1章:区块链基础(2024 最新版)

文章目录 1.1 区块链技术概览&#xff1a;深入探究与实用案例1.1.1 区块链的核心概念1.1.2 重点案例&#xff1a;供应链管理1.1.3 拓展案例 1&#xff1a;数字身份验证1.1.4 拓展案例 2&#xff1a;智能合约在房地产交易中的应用 1.2 主流公链介绍1.2.1 公链的核心概念1.2.2 重…

Qt for android : Qt6.6.2 搭建 环境

环境说明 参考Qt助手: Assistant 6.6.2 (MinGW 11.2.0 64-bit) ***Gradle : Gradle wrapper, version 8.3***JDK11 SDK Tools / NDK 25.1.8937393 参考 Qt For Android : Qt5.13.1 Qt for android: Qt6.4搭建环境遇到的几个问题

MySQL数据库基础(五):SQL语言讲解

文章目录 SQL语言讲解 一、SQL概述 二、SQL语句分类 1、DDL 2、DML 3、DQL 4、DCL 三、SQL基本语法 1、SQL语句可以单行或多行书写&#xff0c;以分号结尾 2、可使用空格和缩进来增强语句的可读性 3、MySQL数据库的SQL语句不区分大小写&#xff0c;关键字建议使用大写…

MongoDB从入门到实战之.NET Core使用MongoDB开发ToDoList系统(3)-系统数据集合设计

前言 前几章教程我们把ToDoList系统的基本框架搭建好了&#xff0c;现在我们需要根据我们的需求把ToDoList系统所需要的系统集合&#xff08;相当于关系型数据库中的数据库表&#xff09;。接下来我们先简单概述一下这个系统主要需要实现的功能以及实现这些功能我们需要设计那些…

开源PDF工具 Apache PDFBox 认识及使用(知识点+案例)

文章目录 前言源码获取一、认识PDFBox二、导入依赖三、基础功能demo1&#xff1a;读取pdf所有内容demo2&#xff1a;读取所有页内容&#xff08;分页&#xff09;demo3&#xff1a;添加页眉、页脚demo4&#xff1a;添加居中45文字水印demo5&#xff1a;添加图片到右上角 参考文…

云计算基础-存储基础

存储概念 什么是存储&#xff1a; 存储就是根据不同的应用程序环境&#xff0c;通过采取合理、安全、有效的方式将数据保存到某些介质上&#xff0c;并能保证有效的访问&#xff0c;存储的本质是记录信息的载体。 存储的特性&#xff1a; 数据临时或长期驻留的物理介质需要保…

【打工日常】使用docker部署可视化工具docker-ui

一、docker-ui介绍 docker-ui是一个易用且轻量化的Docker管理工具&#xff0c;透过Web界面的操作&#xff0c;方便快捷操作docker容器化工作。 docker-ui拥有易操作化化界面&#xff0c;不须记忆docker指令&#xff0c;仅需下载镜像即可立刻加入完成部署。基于docker的特性&…