封装Vue中的axios请求库

  1. 安装axios:首先,在项目中安装axios库。可以使用npm或者yarn进行安装。
    npm install axios
    
  2. 创建封装文件:在src目录下创建一个api文件夹,并在该文件夹下创建一个request.js文件。

  3. 在request.js文件中,引入axios库和Vue:

    import axios from 'axios';
    import Vue from 'vue';
    
  4. 创建一个axios实例,并设置一些默认配置:
    const instance = axios.create({baseURL: 'http://api.example.com', // 设置请求的基础URLtimeout: 5000, // 设置请求超时时间
    });
    
  5. 添加请求拦截器:我们可以在发送请求之前对请求进行拦截,添加一些通用的请求头信息等。
    instance.interceptors.request.use((config) => {// 在发送请求之前做些什么config.headers.Authorization = 'Bearer ' + getToken(); // 示例:给请求头添加身份验证信息return config;},(error) => {// 对请求错误做些什么return Promise.reject(error);}
    );
    
  6. 添加响应拦截器:我们可以在接收到响应之后对响应进行拦截,处理一些公共的错误信息等。
    instance.interceptors.response.use((response) => {// 对响应数据做些什么return response.data;},(error) => {// 对响应错误做些什么return Promise.reject(error);}
    );
    
  7. 封装具体的请求方法:根据项目需求,可以封装常用的GET、POST等请求方法。
    export const get = (url, params) => {return instance.get(url, { params });
    };export const post = (url, data) => {return instance.post(url, data);
    };
    
  8. 在main.js文件中引入request.js,并将其挂载到Vue原型上:
    import request from './api/request';Vue.prototype.$http = request;
    
  9. 在组件中使用封装后的请求方法:
    export default {methods: {fetchData() {this.$http.get('/api/data', { params: { id: 1 } }).then((response) => {// 处理返回的数据}).catch((error) => {// 处理请求错误});},},
    };
    

对axios进行封装有以下几个好处:

  1. 代码复用性:封装axios可以将请求的逻辑和配置进行统一管理,提高代码的可复用性。在多个组件中使用相同的请求方法,避免了重复编写相似的请求代码。

  2. 统一请求配置:通过封装,可以设置全局的请求配置,例如请求超时时间、请求头信息等。这样可以确保所有的请求都遵循相同的规则,并且方便集中管理和修改。

  3. 错误处理和响应拦截:在封装过程中,可以添加请求拦截器和响应拦截器来统一处理错误和响应。例如,可以在请求拦截器中添加身份验证信息,或者在响应拦截器中处理常见的错误状态码。这样可以减少重复的错误处理逻辑。

  4. 可定制性:封装axios可以根据项目需求进行定制。例如,可以根据特定情况对请求参数进行处理或筛选,或者添加自定义的请求头信息。这样可以更好地适应项目的具体要求。

  5. 易于维护:通过封装,可以将网络请求相关的代码从业务逻辑中解耦,使代码结构更清晰易懂。当需要修改请求逻辑时,只需在封装的代码中进行修改,而不需要在多个地方进行修改,提高了代码的可维护性。

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

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

相关文章

点击这里,获取数据治理加速器!

数据管理员:又双叒叕…盘一遍数据,这种工作究竟还要重复多少次?! • 上上个月,发现数据有些问题,我把数据盘了一遍,梳理完数据的关联表才定位到问题; • 上个月,进行数据…

竞赛 题目:基于深度学习的人脸表情识别 - 卷积神经网络 竞赛项目 代码

文章目录 0 简介1 项目说明2 数据集介绍:3 思路分析及代码实现3.1 数据可视化3.2 数据分离3.3 数据可视化3.4 在pytorch下创建数据集3.4.1 创建data-label对照表3.4.2 重写Dataset类3.4.3 数据集的使用 4 网络模型搭建4.1 训练模型4.2 模型的保存与加载 5 相关源码6…

js判断参数是否为空方法

这边记录一下大致的判断情况, 写法一(不推荐): function foo(arg){//写法一:不严谨arg arg ? arg : 我是默认值console.log(arg) }foo(123) //输出:123 foo() //输出:我是默认值 foo(0) …

去除IDEA中代码的波浪线(黄色警示线)

去除IDEA中代码的波浪线 首先是点击File—>Settings 操作如下图所示: 然后点击Editor—>Inspections—>General—>Duplicated code fragment(去掉勾选)—>Apply—>OK 即可,详情请看下图所示:

【Java】Groovy 语言应用场景以及积累

Groovy 是一种多用途的编程语言,它可以用于多种开发场景。以下是 Groovy 可以用于的一些开发领域和示例: 脚本编写: Groovy 的简洁语法和强大的动态特性使其成为编写脚本的理想选择。 def message "Hello, World!" println messag…

7-sqlalchemy快速使用和原生操作、增删查改、增加和基于对象的跨表查询、scoped线程安全、g对象、基本增查改和高级查询

1 sqlalchemy快速使用 2 sqlalchemy原生操作 3 sqlalchemy操作表 3.2 基本增删查改 4 一对多关系 4.1 关系建立 4.2 增加和基于对象的跨表查询 5 多对多关系 5.2 增加和基于对象跨表查 6 scoped线程安全 7 g对象 8 基本增查改 7 常用查询 1 sqlalchemy快速使用 1.1 介绍 # …

什么是数字化工厂?企业数字化转型有什么好处?

科技在发展,时代在进步,全球信息化、数字化的步伐越来越快,数字化转型是否成功也成为企业在未来发展中能否做大做强的关键因素。而数字化工厂就是制造业数字化发展的一个重要发展方向,那么究竟什么是数字化工厂呢?它和…

Linux | 进程间通信

目录 前言 一、进程间通信的基本概念 二、管道 1、管道的基本概念 2、匿名管道 (1)原理 (2)测试代码 (3)读写控制相关问题 a、读端关闭 b、写端关闭 c、读快写慢 d、读慢些快 (4&a…

Unity下载资源且保存

UnityWebRequest(WWW——已过时) 替代:Unity不再支持WWW后,使用UnityWebRequest完成web请求。 Unity - Scripting API: UnityWebRequest (unity3d.com)https://docs.unity3d.com/ScriptReference/Networking.UnityWebRequest.html if (www.isNetworkEr…

GPT-4:论文阅读笔记

GPT-4的输入和输出:输入的内容是文本或图片,输出的内容是文本。因此,GPT-4是一种输入端多模态的模型。GPT-4的效果:在真实世界中还是比不上人类,但是在很多专业性的任务上已经达到了人类的水平,甚至超过人类…

mongdb 删除重复的数据,并保留其中一条

脚本如下,将下面集合与字段替换成自己的集合名和重复字段名即可。 var removeInstanceIdArr = []; var data = db.getCollection("table_test").aggregate( [ { "$group" : { "key": {"Id"…

「全域BI-运营」——助力双11店铺数据可视化

大部分商家主要靠销售商品赚取利润,因此要及时掌握:店铺流量是否异常波动?商品/新品是否有良好竞争力?如何更好营销吸引用户提高客单和回购?掌握这些情况以后,才能进一步决策。 特别是双11期间&#xff0c…

基于51单片机交通灯仿真_紧急开关+黄灯倒计时+可调时间(proteus+代码+报告+讲解视频)

基于51单片机交通灯_紧急开关黄灯倒计时可调时间 ☑️开题报告☑️仿真图(提供源文件):☑️系统硬件设计☑️主控制器选择☑️系统硬件结构图☑️时钟及复位电路☑️指示灯及倒计时模块 ☑️倒计时模块:☑️程序☑️软件主流程框架…

Python实现自动登录+获取数据

前言 大家早好、午好、晚好吖 ❤ ~欢迎光临本文章 Dy这个东西想必大家都用过,而且还经常刷,今天就来用代码,获取它的视频数据 如果有什么疑惑/资料需要的可以点击文章末尾名片领取源码 环境使用 Python 3.8 Pycharm 模块使用 request…

c++ 获取时间 微秒

参考:https://juejin.cn/s/c%2B%2B%20%E8%8E%B7%E5%8F%96%E6%97%B6%E9%97%B4%20%E5%BE%AE%E7%A7%92 在 C 中获取当前时间的微秒数可以使用 头文件中的 std::chrono::high_resolution_clock 类。该类提供了高精度的计时功能,可以精确到纳秒级别。 以下是一个示例代…

js进阶笔记之构造函数

目录 一、构造函数 1、 创建对象 2、new执行过程 3、带参数构造函数 4、实例成员与静态成员 二、内置构造函数 1、Object静态方法 2、包装类型 3、Array 1、map方法 2、find方法 3、findIndex( ) 4、some与every 5、reverse() 6、reduce方法 7、forEach() …

wget 对整站内容进行爬取

如果你想对站点内容进行爬虫,还有一条最简洁的系统原生命令可以搞定: wget --random-wait -r -p -e robotsoff -U mozilla https://example.com/ 加上 -nv 或 --no-verbose 参数后,输出的内容会变得更加简洁; 加上 --accept-re…

DrugMAP: molecular atlas and pharma-information of all drugs学习

DrugMAP:所有药物的分子图谱和制药信息 - PMC (nih.gov) DrugMAP: the molecular atlas and pharma-information of drugs (idrblab.net) 构建了一个描述药物分子图谱和药物信息的新数据库(DrugMAP)。它提供了>30 000种药物/候选药物的相…

bash: ./configure: /bin/sh^M: bad interpreter: No such file or directory

问题背景: 在linux上编译Qt时,遇到这个问题 “bash: ./configure: /bin/sh^M: bad interpreter: No such file or directory” 问题原因: Qt的configure文件是在windows上写的,现在是在ubuntu上进行编译。而linux和windows在换…

数字化转型导师坚鹏:数字化时代银行网点厅堂营销5大难点分析

数字化时代银行网点厅堂营销存在以下5大难点: 1、识别难。识别有效的客户比较难,传统的厅堂识别主要依据客户的衣着气质等主管感受,判断客户是否为潜在中高端客户,提供相关服务。大堂经理主管识别与智能化系统识别相结合&#xf…