vue3 setup基本使用

2024-09-01 13:44

本文主要是介绍vue3 setup基本使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 基本概念

在 Vue 3 中,setup 函数是在组件创建之前调用的,用于初始化组件的响应式数据、计算属性、方法等。setup 函数返回的对象会作为组件的上下文提供给模板,模板中可以直接访问返回的属性和方法。

<template><div><p>{{ message }}</p><button @click="increment">Increment</button></div>
</template><script>
import { ref } from 'vue';export default {setup() {// 响应式数据const message = ref('Hello, Vue 3!');const count = ref(0);// 方法const increment = () => {count.value++;};// 返回的数据和方法将暴露给模板return {message,count,increment};}
}
</script>

二 特点

  • setup函数返回的对象中的内容,可直接在模板中使用。
  • setup中访问thisundefined

函数作用域

在 setup 中,你不再使用 this 来访问组件实例的属性和方法。setup 函数的设计理念是使函数逻辑更加清晰和集中,而不依赖于 this。
组合式 API 的设计

组合式 API 强调通过显式传递参数和返回值来管理组件状态和行为,而不是通过 this 访问实例属性。这样可以提高逻辑的可读性和复用性。

  • setup 函数在组件实例创建之前执行,最早在生命周期钩子之前被调用。这使得你可以在组件实例化之前进行初始化操作。

三 setup 与 Options API 的关系

setup 是 Vue 3 引入的组合式 API 的核心部分,而 Options API 是 Vue 2 中的传统方式。两者的关系如下:

  • Vue2 的配置(datamethos…)中可以访问到 setup中的属性、方法。
  • 但在setup不能访问到Vue2的配置(datamethos…)。
  • 如果与Vue2冲突,则setup优先。

四 setup 语法糖

setup函数有一个语法糖,这个语法糖,可以让我们把setup独立出去,代码如下:

<template><button @click="handleClick">Click me</button><p>Count: {{ count }}</p>
</template><script setup>
import { ref } from 'vue';// 直接在这里定义响应式数据和方法
const count = ref(0);const handleClick = () => {count.value++;
};
</script>

主要特点:

  • 简化语法:不需要显式定义 setup 函数,直接在 <script setup> 中编写逻辑。
  • 自动引入:常用的 Vue 功能(如 ref、computed)自动引入,无需手动导入。
  • 更清晰的代码结构:让组件逻辑和模板结构更加直观和简洁。

五 注意点

  1. 响应式数据

在 setup 中创建响应式数据时,需要使用 Vue 3 提供的 ref 和 reactive API。

ref:用于创建基本类型的响应式数据(如字符串、数字、布尔值等)。

import { ref } from 'vue';const count = ref(0); // 创建一个响应式的基本数据

reactive:用于创建对象和数组的响应式数据。

import { reactive } from 'vue';const state = reactive({count: 0,message: 'Hello, Vue!'
});
  1. 返回值
    setup 函数必须返回一个对象,这个对象中的属性和方法会暴露给组件的模板部分。返回的对象中的数据和方法可以直接在模板中使用。
import { ref } from 'vue';export default {setup() {const count = ref(0);const increment = () => {count.value++;};return {count,increment};}
};
模板部分:<template><button @click="increment">Increment</button><p>{{ count }}</p>
</template>
  1. 生命周期钩子

在 setup 中,可以使用 Vue 3 提供的生命周期钩子函数来替代 Vue 2 的生命周期选项。

onMounted:组件挂载完成后调用。

import { onMounted } from 'vue';onMounted(() => {console.log('Component is mounted.');
});

onUnmounted:组件卸载时调用。

import { onUnmounted } from 'vue';onUnmounted(() => {console.log('Component is unmounted.');
});
  1. 上下文

setup 函数的第二个参数是 context 对象,它包含以下属性:

  • attrs:包含组件的非 props 属性(如 v-bind 绑定的属性)。
  • slots:包含插槽的内容。
  • emit:用于触发事件。
export default {setup(props, context) {const { emit } = context;const handleClick = () => {emit('custom-event', 'payload');};return {handleClick};}
};
  1. 函数和变量的作用域
    在 setup 中定义的函数和变量是局部的,只在 setup 内部可见。要让模板或其他函数访问这些定义,必须从 setup 中返回它们。
export default {setup() {const count = ref(0);const increment = () => {count.value++;};return {count,increment};}
};
  1. 异步操作
    在 setup 中处理异步操作时,确保正确管理其生命周期。通常需要结合生命周期钩子(如 onMounted)来处理异步数据请求,避免内存泄漏。
import { ref, onMounted } from 'vue';export default {setup() {const data = ref(null);onMounted(async () => {data.value = await fetchData();});return {data};}
};
  1. this 的使用
    在 setup 中不使用 this,所有的数据和方法都是通过返回的对象或函数调用进行访问。this 仅在 Options API 中有效。
// Options API
export default {data() {return {count: 0};},methods: {increment() {this.count++;}}
};// Composition API
export default {setup() {const count = ref(0);const increment = () => {count.value++;};return {count,increment};}
};
  1. TypeScript 支持
    setup 函数可以与 TypeScript 结合使用,提供类型检查和代码补全。
import { ref } from 'vue';export default {setup() {const count = ref<number>(0);const increment = () => {count.value++;};return {count,increment};}
};

这篇关于vue3 setup基本使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1127098

相关文章

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

prometheus如何使用pushgateway监控网路丢包

《prometheus如何使用pushgateway监控网路丢包》:本文主要介绍prometheus如何使用pushgateway监控网路丢包问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录监控网路丢包脚本数据图表总结监控网路丢包脚本[root@gtcq-gt-monitor-prome

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期