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

相关文章

使用Python实现矢量路径的压缩、解压与可视化

《使用Python实现矢量路径的压缩、解压与可视化》在图形设计和Web开发中,矢量路径数据的高效存储与传输至关重要,本文将通过一个Python示例,展示如何将复杂的矢量路径命令序列压缩为JSON格式,... 目录引言核心功能概述1. 路径命令解析2. 路径数据压缩3. 路径数据解压4. 可视化代码实现详解1

Pandas透视表(Pivot Table)的具体使用

《Pandas透视表(PivotTable)的具体使用》透视表用于在数据分析和处理过程中进行数据重塑和汇总,本文就来介绍一下Pandas透视表(PivotTable)的具体使用,感兴趣的可以了解一下... 目录前言什么是透视表?使用步骤1. 引入必要的库2. 读取数据3. 创建透视表4. 查看透视表总结前言

Python 交互式可视化的利器Bokeh的使用

《Python交互式可视化的利器Bokeh的使用》Bokeh是一个专注于Web端交互式数据可视化的Python库,本文主要介绍了Python交互式可视化的利器Bokeh的使用,具有一定的参考价值,感... 目录1. Bokeh 简介1.1 为什么选择 Bokeh1.2 安装与环境配置2. Bokeh 基础2

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Pandas使用AdaBoost进行分类的实现

《Pandas使用AdaBoost进行分类的实现》Pandas和AdaBoost分类算法,可以高效地进行数据预处理和分类任务,本文主要介绍了Pandas使用AdaBoost进行分类的实现,具有一定的参... 目录什么是 AdaBoost?使用 AdaBoost 的步骤安装必要的库步骤一:数据准备步骤二:模型

使用Pandas进行均值填充的实现

《使用Pandas进行均值填充的实现》缺失数据(NaN值)是一个常见的问题,我们可以通过多种方法来处理缺失数据,其中一种常用的方法是均值填充,本文主要介绍了使用Pandas进行均值填充的实现,感兴趣的... 目录什么是均值填充?为什么选择均值填充?均值填充的步骤实际代码示例总结在数据分析和处理过程中,缺失数

如何使用 Python 读取 Excel 数据

《如何使用Python读取Excel数据》:本文主要介绍使用Python读取Excel数据的详细教程,通过pandas和openpyxl,你可以轻松读取Excel文件,并进行各种数据处理操... 目录使用 python 读取 Excel 数据的详细教程1. 安装必要的依赖2. 读取 Excel 文件3. 读

解决Maven项目idea找不到本地仓库jar包问题以及使用mvn install:install-file

《解决Maven项目idea找不到本地仓库jar包问题以及使用mvninstall:install-file》:本文主要介绍解决Maven项目idea找不到本地仓库jar包问题以及使用mvnin... 目录Maven项目idea找不到本地仓库jar包以及使用mvn install:install-file基

Python使用getopt处理命令行参数示例解析(最佳实践)

《Python使用getopt处理命令行参数示例解析(最佳实践)》getopt模块是Python标准库中一个简单但强大的命令行参数处理工具,它特别适合那些需要快速实现基本命令行参数解析的场景,或者需要... 目录为什么需要处理命令行参数?getopt模块基础实际应用示例与其他参数处理方式的比较常见问http