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

在这里插入图片描述

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

一、引言

对 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 函数的基本用法,你可以根据自己的需求进行适当的修改和扩展。

相关推荐

  1. 探索Django:打造高效、可扩展的Web应用

    2024-02-17 16:24:02       43 阅读
  2. 鸿蒙应用开发-第二章-函数()

    2024-02-17 16:24:02       39 阅读
  3. Android应用攻略

    2024-02-17 16:24:02       32 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-17 16:24:02       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-17 16:24:02       106 阅读
  3. 在Django里面运行非项目文件

    2024-02-17 16:24:02       87 阅读
  4. Python语言-面向对象

    2024-02-17 16:24:02       96 阅读

热门阅读

  1. 关于管理方法的总结

    2024-02-17 16:24:02       49 阅读
  2. [LeetCode]-回溯-2

    2024-02-17 16:24:02       56 阅读
  3. 开源软件的商业模式

    2024-02-17 16:24:02       50 阅读
  4. Python OpenCV 入门 这篇就够了

    2024-02-17 16:24:02       49 阅读
  5. vivado Convergent Rounding (LSB CorrectionTechnique)

    2024-02-17 16:24:02       52 阅读
  6. 用Python实现对Ajax数据爬取

    2024-02-17 16:24:02       46 阅读
  7. Go:字符串与数字的高效转换

    2024-02-17 16:24:02       46 阅读
  8. Go:UTF-8编码与utf8.DecodeRuneInString函数详解

    2024-02-17 16:24:02       48 阅读