在vue3中如何优雅的管理loading状态

时隔多日,我又来了。近期工作实在是太忙了,基本处于天天加班的状态,整个人都麻木了,导致最近一直没有更新什么东西,感觉都快荒废了。还好,这两天处于下个项目开发前,当前项目已提测,好歹能有一点时间来学点东西,写点东西。

好了,废话不多说,本次是给大家分享一下我这两天写的一个插件。本来是写了一个公共方法自己用来着,想着近期在网上没看到好的方法,索性做成插件,分享出来,也让各位大佬们看看还有没有改进的地方。

直接先上链接vite-plugin-auto-loading

接下来,就说说我为什么要写这个插件,以及这个插件的基本用法

一、当前已有插件的问题

其实,目前对于loading的状态管理已经有很多的处理方案了,简单列举一下

1、请求拦截

也就是在请求接口的时候进行统一封装,发出请求展示loading,请求结束关闭loading。

弊端:公共loading,没法单独配置到各个按钮以及操作上面,同时多个请求的时候不做特殊处理的话loading会闪现

2、公共方法封装

封装一个公共的方法,让后在写具体方法的时候给包一层,方法具体咋写这里就不列举了,给大家看看具体实现

// 原
const fun1 = ()=>{..........}// 改
const fun2 = ()=>{loadingFun(fun1())
}
const fun1 = ()=>{..........}

这种方式的问题,不用说了吧,多了一步包裹的操作,但实际上,这种方式是最简单实现,也是最合理的,想用就用,不想用拉倒,具体传参与否就看自己怎么封装了。

3、笨办法,每个地方单独写(反正是复制粘贴)

const fun1 =async ()=>{loading.value = truetry{await api() }catch (e) {loading.value = false}
}

相信这种写法的不在少数,毕竟有时候因为各种原因没工夫去封装,但又要管理loading,反正我自己用这种方式用的也不少。

4、其他方法

其他还有一些通过自定义指令啊,或者通过注入,更有甚者用vue3不建议的mixin的,这就不提了,很多时候其实大家都是迫于无奈,想改吧,牵扯太大,时间不够等等,就不说了。

二、要处理的问题

1、得能在任意的地方使用

2、尽可能少的代码,不要繁琐的步骤

3、要不改变原方法结构

4、要简单易懂

三、解决

就上述说的一样,我自己也一直在想怎么才能很好的处理loading状态,毕竟我自己很懒,能少写代码就少写代码,于是经过一段时间的问题修复,我的第一个版本成了。下面说一下具体用法,这里说一下前提,vue3+vite

1、安装
npm install vite-plugin-auto-loading -D
2、配置
// vite.config.ts
import { defineConfig } from 'vite'
import { autoLoadingPlugin } from 'vite-plugin-auto-loading'
export default defineConfig({
plugins: [autoLoadingPlugin()]
})
// autoLoadingPlugin({debug: true // 开启调试日志}) 是否需要日志自选
3、使用

插件会自动读取loading变量同名的方法,且同时含有async以及await,如loading.handleSearch会根据handleSearch的执行结果来改变状态,loading中没有同名,或者只有async或await,都不会做任何操作

<el-button :loading="loading.handleSearch">查询</el-button><list :loading="loading.getData"></list>const loading = reactive({getData: false,handleSearch: false,
});const getData = async() =>{await getApi(xxxxxxxx)
}const handleSearch = async() =>{const queryData = {a:1,b:2}await postApi(queryData)
}
4、原理

通过vite插件,读取.vue文件中声明的loading变量,不论是ref还是reactive声明的都可,获取里面的key值,并匹配与key值同名的方法,当匹配到的时候,查看是否满足同时有async 以及await,符合条件的时候重写方法。如:

// 原
const handleSearch = async() =>{const queryData = {a:1,b:2}await postApi(queryData)
}// 变为
const handleSearch = async() =>{loading.handleSearch = truetry{const queryData = {a:1,b:2}await postApi(queryData)} finally {loading.handleSearch = false}}

当然,这些都是在vite编译的时候进行,不用我们进行任何操作。

注意:不仅仅是箭头函数的方式可以,其他声明函数的方式也可以的,有做了适配

有其他问题的话,欢迎大家指正哦,转载请注明出处!

源码地址:

github:https://github.com/sha-chong/vite-plugin-auto-loading

gitee:https://gitee.com/shachongji/vite-plugin-auto-loading

查看源码可以的话请给我一个star(^U^)ノ~YO

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

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

相关文章

大模型(LLMs)RAG 版面分析——表格识别方法篇

大模型&#xff08;LLMs&#xff09;RAG 版面分析——表格识别方法篇 一、为什么需要识别表格&#xff1f; 表格的尺寸、类型和样式展现出多样化的特征&#xff0c;如背景填充的差异性、行列合并方法的多样性以及内容文本类型的不一致性等。同时&#xff0c;现有的文档资料不…

基于Matlab PCA人脸识别(二)

1.2 向量与基变换 1.2.1 内积与投影 两个大小相同向量的内积被定义如下&#xff1a;

RE正则表达式 小练习

题目&#xff1a; 答案&#xff1a;

整理:4篇专注于多模态大语言模型(MLLM)的瘦身变体论文

近年来&#xff0c;随着人工智能技术飞速发展&#xff0c;大语言模型&#xff08;LLM&#xff09;和多模态大语言模型&#xff08;MLLM&#xff09;成为了炙手可热的明星。它们不仅能处理文字&#xff0c;还能看图识字&#xff0c;简直是“全能选手”。这种能力得益于模型中加入…

车轮上的科技:Spring Boot汽车新闻集散地

1系统概述 1.1 研究背景 随着计算机技术的发展以及计算机网络的逐渐普及&#xff0c;互联网成为人们查找信息的重要场所&#xff0c;二十一世纪是信息的时代&#xff0c;所以信息的管理显得特别重要。因此&#xff0c;使用计算机来管理汽车资讯网站的相关信息成为必然。开发合适…

go-zero(五) 模板定制

go-zero 模板定制 goctl 代码生成是基于 go 的模板去实现数据驱动的&#xff0c;实际开发中&#xff0c;使用goctl 生成的代码&#xff0c;并不符合我们的需求。 例如&#xff0c;我们刚刚的使用错误管理&#xff0c;我们需要在handler中返回的错误信息。 一、生成模板 首先…

ICML24最新开源时序基础模型MOMENT

论文标题&#xff1a;MOMENT: A Family of Open Time-series Foundation Models 论文链接&#xff1a;https://arxiv.org/pdf/2402.03885 前言 当前时间序列数据上预训练大型模型面临以下挑战&#xff1a;(1) 缺乏大型且统一的公共时间序列数据集&#xff0c;(2) 时间序列特…

Flink和Spark的区别是什么?各自的应用场景是什么?

一、Flink是什么&#xff1f; Flink&#xff1a;Flink 是一个分布式流处理框架&#xff0c;其架构基于流计算&#xff0c;将一切都看作是流。它采用了一种基于事件驱动的架构&#xff0c;数据以流的形式源源不断地进入系统&#xff0c;并且能够实时处理这些数据。例如&#xf…

2024.11.18晚Linux复习课笔记

第一章 cat -n显示行号 -b不显示空行号 pwd 打印当前的工作目录 cd ls 打印当前工作的所有文件 -a -A -l:显示当前文件的详细信息 -r:递归显示 passwd:修改密码 ip a 查看ip地址 poweroff shutdown -h 关机 reboot shutdown -r 第二章 man --help …

基于Spring Boot+Unipp的博物馆预约小程序(协同过滤算法、二维码识别)【原创】

&#x1f388;系统亮点&#xff1a;协同过滤算法、二维码识别&#xff1b; 一.系统开发工具与环境搭建 1.系统设计开发工具 后端使用Java编程语言的Spring boot框架 项目架构&#xff1a;B/S架构 运行环境&#xff1a;win10/win11、jdk17 前端&#xff1a; 技术&#xff1a;框…

Scaling Law的“终结“还是新起点?——开源实践者的深度思考

作者&#xff1a;宋大宝&#xff0c;与大宝同学因那篇《回顾总结展望「融合RL与LLM思想&#xff0c;探寻世界模型以迈向AGI」》结识于今年春天&#xff0c;虽我们当时某些思想观念有些出入&#xff0c;也碰撞出了很多火花与共鸣&#xff0c;并持续地相互启发的走到了现在。他是…

【qt】控件4

1.Qradiobutton(单选按钮) ui界面有三个按钮&#xff0c;应该文本框&#xff0c;根据不同的按钮来改变不同文本框的内容 根据不同的单选按钮改变不同的文本框。 Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this);ui->radioB…

Day02_AJAX综合案例 (黑马笔记)

Day02_AJAX综合案例 目录 Day02_AJAX综合案例 学习目标 01.案例_图书管理-介绍 目标 讲解 小结 02.Bootstrap 弹框_属性控制 目标 讲解 小结 03.Bootstrap 弹框_JS控制 目标 讲解 小结 04.案例_图书管理_渲染列表 目标 讲解 小结 05.案例_图书管理_新增图书…

六、代码生成,《编译原理》(本科教学版),第2版

文章目录 零、前言0.1 编译器前端到后端 一、代码生成1.1 代码生成的任务1.2 给数据分配计算资源1.3 给代码选择合适的机器指令1.4 栈式计算机1.4.1 栈式计算机Stack的结构1.4.2 栈计算机的指令集1.4.3 变量的内存分配伪指令1.4.4 栈式计算机的代码生成1.4.4.1 递归下降代码生成…

Android集成FCM(Firebace Cloud Messaging )

集成FCM官方文档 Firebace主页面 将 Firebase 添加到您的 Android 应用 1、进入Firebace页面&#xff0c;创建自己的项目 2、点击自己创建好的项目&#xff0c;在右侧选择Cloud Messaging 3、点击Android去创建 google-services.json 4、将下载的 google-services.json 文件…

D2076——一款双通道音频功率放大器【青牛科技】

概述&#xff1a; D2076是一款双通道音频功率放大器&#xff0c;最低工作电压可到1.0V。适用于 便携式小型收音机或立体声耳机作双通道或BTL应用。 主要特点&#xff1a; BTL工作&#xff0c;Po90mW&#xff08;典型值&#xff09; 外接元器件少 通过外接PNP三极管作为…

智慧社区平台系统提升物业管理效率与居民生活质量

内容概要 智慧社区平台系统是为应对现代城市管理挑战而诞生的重要工具。随着城市化进程的加快&#xff0c;传统的物业管理方式已经难以满足日益增长的居民需求和管理复杂性。因此&#xff0c;引入智能化管理手段显得尤为重要。这个系统不仅仅是一个简单的软件&#xff0c;它是…

【langchain4j】AIservices能够实现更加灵活的chain

文章目录 AI service介绍如何工作的AiServices提供的能力支持的返回形式 简单的例子&#xff1a;接收用户消息&#xff0c;并按规定返回接收单个变量接收更多动态变量 advanced RAGChaining multiple AI Services&#xff1a;多个AiSerives合并到一起相关教程&#xff1a;[Lang…

JavaScript 中字符串和数组的概念解析与多角度对比区分

文章目录 &#x1f4af;前言&#x1f4af;字符串&#xff08;String&#xff09;&#x1f4af;数组&#xff08;Array&#xff09;&#x1f4af;字符串与数组的相同点与不同点&#x1f4af;字符串和数组的实际应用场景&#x1f4af;字符串与数组的互转&#x1f4af;字符串和数组…

4K双模MiniLED显示器哪个好

4K双模MiniLED显示器哪个好&#xff1f;现在市面上的4K双模MiniLED显示器太多了&#xff0c;琳琅满目&#xff0c;今天就给大家列举一下7款当下火热到爆炸的品牌&#xff0c;看看4K双模MiniLED显示器哪个好。 4K双模MiniLED显示器哪个好 - HKC G27M7PRO HKC G27M7Pro 是一款性…