vuejs中封装axios请求集中管理

15ff9081f789b1dfa0cabf8a2f1def94.jpeg

vuejs中封装axios请求集中管理

前言

vuejs中,使用axios请求数据,一般会封装一个请求方法,然后在每个页面中调用,这样就造成代码冗余,导致代码可读性差,维护困难。

在项目当中,单独使用axios或者在main.js中全局引入axios,然后在每个页面中调用,这样做,不是不可以,但是会使项目的请求非常分散,这样是不易代码维护的,如果一些要求比较高的项目,是需要对请求进行封装的。

我们需要将axios请求集中管理,方便以后维护。

未封装前代码

若没有进行封装,则需要在具体单文件中,单独引入axios,然后进行请求。

如下所示

<template><div><div><el-button type="primary"  @click="handleBtnGetJoke">请求数据</el-button><el-button type="danger" @click="handleBtnClearData" v-if="aDatas.length > 0?true:false">清空数据</el-button></div>
</template><script setup>
// 引入axios    
import axios from "axios";let aDatas = ref([]);
let page = ref(1);
let pagesize = ref(5);// 请求数据
async function handleBtnGetJoke() {const params = {key: 'aa1b7ad08be2a09a4e0d2d46897e2dc8',page: page.value,pagesize:pagesize.value,time: 1418816972}// 使用axios中的get请求数据const response = await axios.get('/api/joke/content/text.php',{params})console.log(response);if(response.status == 200) {const { data } = response.data.result;console.log(data);aDatas.value = aDatas.value.concat(data);}
}// 加载数据,叠加
function handleBtnLoading() {page.value++;handleBtnGetJoke(); //getJokeListsData();
}// 清空数据
function handleBtnClearData() {aDatas.value = [];
}
</script><style scoped>
.joke-list {list-style-type: decimal;list-style-position: outside;padding: 5px 0;border-bottom: dashed 1px #ccc;
}.loading {margin: 0 auto;text-align:center;
}
</style>

如果没有进行axios封装,那么只要项目中的单文件组件,需要请求数据,那么就必须引入axios,而且需要频繁的写axios.get()axios.post()

如果不想重复引入axios,也可以在main.js文件中,进行axios的全局的引入

import { createApp } from 'vue';import axios from "axios";import ElementPlus from 'element-plus';
//import 'element-plus/lib/theme-chalk/index.css';   
import 'element-plus/dist/index.css';
import App from './App.vue';const app = createApp(App);
// 全局 挂载axios,在vue2.0里面是挂载在原型下的vue.prototype.$axios = axios,写过vue2.0的代码的应该不会陌生
app.config.globalProperties.$axios = axiosapp.use(ElementPlus)app.mount('#app');

那在单文件组件中,就可以直接使用

<template><div><div><el-button type="primary"  @click="handleBtnGetJoke">请求数据</el-button><el-button type="danger" @click="handleBtnClearData" v-if="aDatas.length > 0?true:false">清空数据</el-button></div>
</template><script setup>
// 需要引入getCurrentInstance() 获取当前实例
import { ref,getCurrentInstance  } from "vue";
// 调用getCurrentInstance() 获取axios实例
const { proxy } = getCurrentInstance();let aDatas = ref([]);
let page = ref(1);
let pagesize = ref(5);async function handleBtnGetJoke() {const params = {key: 'aa1b7ad08be2a09a4e0d2d46897e2dc8',page: page.value,pagesize:pagesize.value,time: 1418816972}// 需要proxy.$axios.get() 这样才能使用const response = await proxy.$axios.get('/api/joke/content/text.php',{params})console.log(response);if(response.status == 200) {const { data } = response.data.result;console.log(data);aDatas.value = aDatas.value.concat(data);}
}// 加载数据,叠加
function handleBtnLoading() {page.value++;handleBtnGetJoke(); 
}// 清空数据
function handleBtnClearData() {aDatas.value = [];
}
</script><style scoped>
.joke-list {list-style-type: decimal;list-style-position: outside;padding: 5px 0;border-bottom: dashed 1px #ccc;
}.loading {margin: 0 auto;text-align:center;
}
</style>

类型上面的代码,把axios全局挂载在proxy上,然后就可以在vue文件中直接使用proxy.$axios.get()了,这样单文件组件中,就不用每次都引入axios了。

但是同样是存在弊端的,这样每次请求数据,都需要把params参数传进去,这样就比较麻烦,所以,我们还可以封装一个get请求方法,把params参数封装到get请求方法中,这样每次请求数据,就不用每次都传params参数了。

封装axios请求数据的方法

1. 封装一个request.js文件,用于请求数据,这个文件中,封装了axios请求数据的方法,以及请求拦截和响应拦截。

封装了getpost请求方法,以及请求拦截和响应拦截。一般会放在src目录下的api文件夹中。

如下示例所示

import axios from 'axios';
// 接口地止
const baseUrl = '/api/joke/content/list.php';// get请求方法封装,具体某个页面当中的get请求方法,可以调用这个方法
export const getJokeLists =  (params)=> {return  axios.get(`${baseUrl}`,{params:{...params}})
}

2. 在组件中进行使用

在组件中,使用request.js中的方法,进行请求数据。

如下示例所示

<template><div><div><el-button type="primary"  @click="getJokeListsData">请求数据</el-button><el-button type="danger" @click="handleBtnClearData" v-if="aDatas.length > 0?true:false">清空数据</el-button><div><ul v-if="aDatas.length > 0?true:false"><li class="joke-list" v-for="item in aDatas":key="item.hashId">{{ item.content }}</li><div class="loading" v-if="aDatas.length > 0?true:false"> <el-button size="mini"  type="primary" @click="handleBtnLoading" >加载</el-button></div></ul> </div>
</template><script setup>
import { getJokeLists } from "../../api/request.js";let aDatas = ref([]);
let page = ref(1);
let pagesize = ref(5);async function getJokeListsData() {// 请求参数const params ={key: "aa1b7ad08be2a09a4e0d2d46897e2dc8",page: page.value,pagesize:pagesize.value,time: 1418816972}// 这里的话,直接调用request.js中的方法,进行请求数据,就可以了的const response = await getJokeLists(params)console.log(response);if(response.status == 200) {const { data } = response.data.result;console.log(data);aDatas.value = aDatas.value.concat(data);}
}// 加载数据,叠加
function handleBtnLoading() {page.value++;getJokeListsData();
}// 清空数据
function handleBtnClearData() {aDatas.value = [];
}</script><style scoped>
.joke-list {list-style-type: decimal;list-style-position: outside;padding: 5px 0;border-bottom: dashed 1px #ccc;
}.loading {margin: 0 auto;text-align:center;
}
</style>

你会发现,如果封装了页面的axiosget请求,

那么,我们就可以直接使用get请求了,不需要再写get请求的代码了,直接调用get请求的方法就可以了,是不是很方便呢?

因为我们的get请求,在request.js中已经封装好了,所以,我们直接调用就可以了.封装post也是类似的

但凡一些写得比较规范的项目里,都是会对axios进行封装的,这样便于代码的管理和复用,也便于项目的维护

封装有封装的好处,不封装,也有不封装的好处,对于初学者,写零散的axios请求,比较直接,而封装后的代码,需要开发者自己去追溯

封装的代码,对于初学者,可能比较难以理解,所以,对于初学者,建议先写零散的代码,等够熟练了,然后再进行封装,在自己不是很熟练的时候,先写零散的代码,这样,对封装,有一个比较直观的理解

而不要一上来就封装请求代码的,给自己挖坑的,确定零散的代码没有问题,再封装,这样,对初学者,比较友好

vuejs中缓存组件状态-keepAlive

2023-09-30

d50f346963c6992e77553b6b7a921463.jpeg

前后端联调前-一个前端动手写代码前的思考

2023-09-21

c3d2a128f5031691d34a19efe1b14079.jpeg

vite构建的本地开发环境请求第三方接口时如何解决跨域问题

2023-09-17

fe05befe75c6f7e2be2c204b12c4c281.jpeg

VuePress网站如何使用axios请求第三方接口

2023-09-16

ae6b56a0cd86e40f25d6fb70d4fbb121.jpeg

通过分享缩短链接进行赚钱

2023-09-15

8c93be4930b76b7d727fa93a80545572.jpeg

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Elasticsearch:语义搜索快速入门

这个交互式 jupyter notebook 将使用官方 Elasticsearch Python 客户端向你介绍 Elasticsearch 的一些基本操作。 你将使用 Sentence Transformers 进行文本嵌入的语义搜索。 了解如何将传统的基于文本的搜索与语义搜索集成&#xff0c;形成混合搜索系统。在本示例中&#xff0…

在原生html中使用less

引入less <link rel"stylesheet/less" href"./lessDemo.less" /><script src"./js/less.min.js"></script> less.min.js文件下载地址:https://github.com/less/less.js 注意&#xff1a;less文件在前&#xff0c;js文件在后…

Ultra-Fast-Lane-Detection-v2 {后处理优化}//参考

采用三次多项式拟合生成的anchor特征点&#xff0c;在给定的polyfit_draw函数中&#xff0c;degree参数代表了拟合多项式的度数。 具体来说&#xff0c;当我们使用np.polyfit函数进行数据点的多项式拟合时&#xff0c;我们需要指定一个度数。这个度数决定了多项式的复杂度。例…

机器学习-数值特征

离散值处理 import pandas as pd import numpy as npvg_df pd.read_csv(datasets/vgsales.csv, encoding "ISO-8859-1") vg_df[[Name, Platform, Year, Genre, Publisher]].iloc[1:7]NamePlatformYearGenrePublisher1Super Mario Bros.NES1985.0PlatformNintendo2…

Qt + FFmpeg 搭建 Windows 开发环境

Qt FFmpeg 搭建 Windows 开发环境 Qt FFmpeg 搭建 Windows 开发环境安装 Qt Creator下载 FFmpeg 编译包测试 Qt FFmpeg踩坑解决方法1&#xff1a;换一个 FFmpeg 库解决方法2&#xff1a;把项目改成 64 位 后记 官方博客&#xff1a;https://www.yafeilinux.com/ Qt开源社区…

通用监控视频web播放方案

业务场景 对接监控视频&#xff0c;实现海康大华等监控摄像头的实时画面在web端播放 方案一&#xff0c;使用 RTSP2webnode.jsffmpeg 说明&#xff1a;需要node环境&#xff0c;原理就是RTSP2web实时调用ffmpeg解码。使用单独html页面部署到服务器后&#xff0c;在项目中需要播…

小谈设计模式(9)—工厂方法模式

小谈设计模式&#xff08;9&#xff09;—工厂方法模式 专栏介绍专栏地址专栏介绍 工厂方法模式角色分类抽象产品&#xff08;Abstract Product&#xff09;具体产品&#xff08;Concrete Product&#xff09;抽象工厂&#xff08;Abstract Factory&#xff09;具体工厂&#x…

美股游戏股分析:微软收购游戏公司动视暴雪将迎来一个重要里程碑

来源&#xff1a;猛兽财经 作者&#xff1a;猛兽财经 总结&#xff1a; &#xff08;1&#xff09;微软(MSFT)收购动视暴雪(ATVI)的交易在做出重大让步后目前已经获得了欧盟和美国的监管批准。 &#xff08;2&#xff09;英国英国竞争和市场管理局(CMA)最初对微软收购动视暴雪…

java CPU 或者内存 异常排查

java CPU 或者内存 异常排查 提示&#xff1a;需要基础环境和配置上java-home CPU 或者内存 异常排查 java CPU 或者内存 异常排查前言一、java文件上传&#xff08;Test.java&#xff09;二、转换为class三、执行命令&#xff0c;启动文件四、使用top命令查看五、下载文件&…

Maven 下载安装配置

Maven 下载安装配置 下载 maven maven 官网&#xff1a;https://maven.apache.org/ maven 下载页面&#xff1a;https://maven.apache.org/download.cgi 安装 maven 将下载的apache-maven.zip文件解压到安装目录 将加压后的apache-maven目录改名为maven maven 配置环…

软件设计模式系列之二十五——访问者模式

访问者模式&#xff08;Visitor Pattern&#xff09;是一种强大的行为型设计模式&#xff0c;它允许你在不改变被访问对象的类的前提下&#xff0c;定义新的操作和行为。本文将详细介绍访问者模式&#xff0c;包括其定义、举例说明、结构、实现步骤、Java代码实现、典型应用场景…

Python-将常用库写入到一个Python程序里面,后续使用直接导入这个文件即可,就相当于导入了所有的库,就不用每次都写一堆的import了

sys.path.append(rD:\Backup\Documents) # 上方代码中的这一句 是我的常用库 所在的文件路径 当然&#xff0c;文件名建议写英文&#xff08;比如&#xff1a;Common_use_lib.py&#xff09;&#xff0c; 不要写&#xff1a;常用库... 我这里只是演示使用&#xff0c;方便理…