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

在这里插入图片描述

🤍 前端开发工程师、技术日更博主、已过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 函数的基本用法,你可以根据自己的需求进行适当的修改和扩展。

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

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

相关文章

蓝桥省赛真题|简单:分数

题目链接:https://www.lanqiao.cn/problems/610/learning/?page1&first_category_id1&second_category_id3&tags2018&name%E5%88%86%E6%95%B0 题不难,但是可以帮助编程时好的习惯的养成,更加注意一些细节。 注意几个地方︰…

C++ STL->list模拟实现

theme: smartblue list list文档 list是可以在常数范围内在任意位置进行插入和删除的序列式容器,并且该容器可以前后双向迭代。list的底层是双向链表结构,双向链表中每个元素存储在互不相关的独立节点中,在节点中通过指针指向 其前一个元素…

solara,好用的 Python 太阳能系统的建模库!

🏷️个人主页:鼠鼠我捏,要死了捏的主页 🏷️付费专栏:Python专栏 🏷️个人学习笔记,若有缺误,欢迎评论区指正 前言 大家好,今天为大家分享一个超级厉害的 Python 库 - solara。 Github地址:https://github.com/widgetti/solara 在可持续能源领域,太阳能是一种…

Github 2024-02-17 开源项目日报 Top10

根据Github Trendings的统计,今日(2024-02-17统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Python项目4TypeScript项目3Rust项目2Jupyter Notebook项目1PowerShell项目1JavaScript项目1 Black&#xff…

linux系统---防火墙

目录 一、防火墙的认识 1.防火墙定义 2.防火墙分类 二、Linux系统防火墙 1.Netfilter 2.防火墙工具介绍 2.1iptables 2.2firewalld 2.3nftables 2.4netfilter的五个勾子函数和报文流向 2.4.1五个勾子 2.4.2三种报文流向 3.iptables 3.1iptables概述 3.2iptables…

移动WEB开发知识总结

浏览器现状 PC端常见浏览器 360浏览器、谷歌浏览器、火狐浏览器、QQ浏览器、百度浏览器、搜狗浏览器、IE浏览器。 移动端常见浏览器 UC浏览器,QQ浏览器,欧朋浏览器,百度手机浏览器,360安全浏览器,谷歌浏览器&#xf…

TenorFlow多层感知机识别手写体

文章目录 数据准备建立模型建立输入层 x建立隐藏层h1建立隐藏层h2建立输出层 定义训练方式建立训练数据label真实值 placeholder定义loss function选择optimizer 定义评估模型的准确率计算每一项数据是否正确预测将计算预测正确结果,加总平均 开始训练画出误差执行结…

微信网页版能够使用(会顶掉微信app的登陆)

一、文件结构 新建目录chrome新建icons,其中图片你自己找吧新建文件manifest.json新建文件wx-rules.json 二、文件内容 对应的png你们自己改下 1、manifest.json {"manifest_version": 3,"name": "wechat-need-web","author…

揭开Markdown的秘籍:引用|代码块|超链接

🌈个人主页:聆风吟 🔥系列专栏:Markdown指南、网络奇遇记 🔖少年有梦不应止于心动,更要付诸行动。 文章目录 📋前言一. ⛳️Markdown 引用1.1 🔔引用1.2 🔔嵌套引用1.3 &…

网络原理-TCP_IP(6)

网络层 在复杂的网络环境中确定一个合适的路径. IP协议 与TCP协议并列,都是网络体系中最核心的协议. 基本概念 主机:配有IP地址,但是不进行路由控制的设备; 路由器:即配有IP地址,又能进行路由控制; 节点:主机和路由器的统称; 协议头格式 4位版本号(version):指定IP协议的版…

Vue的一些基础设置

1.浏览器控制台显示Vue 设置找到扩展,搜索Vue 下载这个 然后 点击扩展按钮 点击详细信息 选择这个,然后重启一下就好了 ——————————————————————————————————————————— 2.优化工程结构 src的components里要…

wayland(xdg_wm_base) + egl + opengles 纹理贴图进阶实例(四)

文章目录 前言一、使用gstreamer 获取 pattern 图片二、代码实例1. pattern 图片作为纹理数据源的代码实例1.1 基于opengles2.0 接口的 egl_wayland_texture2_1.c1.2 基于opengles3.0 接口的 egl_wayland_texture3_1.c2. xdg-shell-client-protocol.h 和 xdg-shell-protocol.c3…

IDEA中的神仙插件——Smart Input (自动切换输入法)

IDEA中的神仙插件——Smart Input (自动切换输入法) 设置 更多功能详见官方文档:Windows版SmartInput使用入门

面试经典150题——串联所有单词的子串(困难)

"Opportunities dont happen, you create them." ​ - Chris Grosser 1. 题目描述 2. 题目分析与解析 2.1 思路一——暴力求解 遇见这种可能刚开始没什么思路的问题,先试着按照人的思维来求解该题目。对于一个人来讲,我想要找到 s 字符串中…

Hive拉链表设计、实现、总结

水善利万物而不争,处众人之所恶,故几于道💦 文章目录 环境介绍实现1. 初始化拉链表2. 后续拉链表数据的更新 总结彩蛋 - 想清空表的数据:转成内部表,清空数据后,再转成外部表,将分区目录删掉&am…

无心剑英译仓央嘉措《永在我心》

永在我心 Forever in My Heart 仓央嘉措 By Tsangyang Gyatso 这么多年 你一直在我心口幽居 我放下过天地 放下过万物 却从未放下过你 so many years slipped away you’ve been living in my heart I’ve dropped heaven and earth even dropped everything but never dr…

OWASP TOP10

OWASP TOP10 OWASP网址:http://ww.owasp.org.cn A01:失效的访问控制 例如:越权漏洞 案例1: 正常:每个人登录教务系统,只能查询自己的成绩信息 漏洞:张三登录后可以查看自己的成绩 例如&…

人工智能学习与实训笔记(五):神经网络之推荐系统处理

目录 ​​​​​​​七、智能推荐系统处理 7.1 常用的推荐系统算法 7.2 如何实现推荐​​​​​​​ 7.3 基于飞桨实现的电影推荐模型 7.3.1 电影数据类型 7.3.2 数据处理 7.3.4 数据读取器 7.3.4 网络构建 7.3.4.1用户特征提取 7.3.4.2 电影特征提取 7.3.4.3 相似度…

智能网卡(SmartNIC):增强网络性能

在当今的数字时代,网络性能和数据安全是各行各业面临的关键挑战。智能网卡是一项颠覆性的技术创新,对增强网络性能和加强数据安全性具有关键推动作用。本文旨在探讨智能网卡的工作原理及其在不同应用场景中的重要作用。 什么是智能网卡? 智…

Rust 基本环境安装

rust 基本介绍请看上一篇文章:rust 介绍 rustup 介绍 rustup 是 Rust 语言的安装器和版本管理工具。通过 rustup,可以轻松地安装 Rust 编译器(rustc)、标准库和文档。它也允许你切换不同的 Rust 版本或目标平台,以及…