热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

axios同时多个请求_Vue中Axios的封装管理

Axios封装定义Axios是一个基于promise的HTTP库,可以用在浏览器和node.js中。特性支持PromiseAPI拦截请求和响应转换请求数据和响应数据自

Axios 封装

aecb8f822a73d8756cf505e756a6f63f.png

定义

Axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中。

特性

  • 支持Promise API
  • 拦截请求和响应
  • 转换请求数据和响应数据
  • 自动转换JSON数据
  • ##### 客户端支持 XRSF

回归正题

在Vue 项目开发中,我们与接口打交道最多了,如何来优雅的使用Axios变得尤为重要了。
通常我们通过客户端向后端发送请求来接收接口数据,然后将这些接口数据完美的呈现到网页上。

同时,与接口打交道那么就会用到网络请求,与 Vue 结合的网络请求库有哪些呢?

  • vue-resource

  • axios   官方推荐

  • fetch

本章将使用 axios  来完成接口的请求,以及对axios 请求的封装,来满足业务开发。

一次编写, 终身受用 ?

开始

安装axios

yarn add axios

封装http.js

创建单独文件来封装axios,封装的同时,你需要和 后端  协商好一些约定,请求头 , 状态码, 请求超时时间…….

引入必要的UI 提示框, 不同的状态码,提示不同的响应,

请求头 :  来实现一些具体的业务,必须携带一些参数才可以请求(例如:会员业务)

状态码 :   根据接口返回的不同status , 来执行不同的业务,这块需要和后端约定好。

请求拦截器:  根据请求的请求头设定,来决定哪些请求可以访问。

响应拦截器:这块就是根据 后端 返回来的状态码判定执行不同业务

d41be558eccbdf21aaf14397e99c6f6b.png

完整代码

配置多域名请求不同URL

一般自己写项目时, 一个接口URL 就可以了。但在实际项目开发中,一个项目可能会请求不同的服务器的url,这时,我们简单的配置下访问接口域名,然后不同域名的接口,直接换对象调用即可,这样不管有多少个不同的接口,我们都可以很好的管理使用。

59118550ca74124844075ff5695bf68c.png

完整代码

到现在 axios 基本封装完成,可以满足你基本业务需求了

axios 封装完事了, 接下来就是封装单独的业务模块请求了,这块怎么划分 完全看个人风格,, 下面我会列出 两种

业务需求注意:

  • 必须引入 http.js  axios

  • 必须引入 base.js  接口url

  • 必须在Vue 入口文件下,引入业务需求 api.js,并且将api挂载到Vue 原型上

  • 剩下就是写你对应的业务需求了

风格1

所有请求都写到一个api.js  文件下

43e0e6e8334b85b086e89d2eddc154f3.png

完整代码

如何使用呢?
全局挂载`api.js`

53293053e4bc383dec4551a02817728c.png

业务组件调用

272d2b72a41a24a2dfa97db206c3f882.png


风格2

可以新建对应组件模块的文件来管理对应的 业务请求,这样接口出现问题,定位错误快,最后将不同的文件 引入到一个 api,js 里, 这样管理起来很方便。

757ecef032f3acec114343ba3d9ae005.png

2791f9bb9e21acf75a3da72cf0d6b4c0.png

如何使用呢?

d0b784b2c72ba6b561378cd15d97803a.png

封装 与 不封装对比

6432d6caa93aa4bc0c889093d2428921.png

没有封装, 裸奔的Axios

f8e703057e71421959e51d53b660b3c6.png

最后

到现在,Axios基本封装完事了,也封装了业务模块的请求,基本上可以满足基本的业务需求了。如果项目还需要其它需求,还可以在原有的上面进行再次封装。

封装后,如果项目有接口域名有变动,执行调用base.js下的域名对象即可。

历史精彩文章:

2020前端技术面试必备Vue:(一)基础快速学习篇

2020前端技术面试必备Vue:(二)Router篇

2020前端技术面试必备Vue:(二)组件篇

2020前端技术面试必备Vue:(四)Vuex状态管理

以上是Vue全家桶系列

全栈进阶:Nginx基本功能及其原理

TypeScript 快速入门(基础篇)
MYSQL常用操作指令

更多精彩文章在公众号

69425ff650eedd92eaea20cea5ec33fa.png

                                                                  原创不易 , 觉得不错 点个赞?

“写文章不挣钱,交个朋友”




推荐阅读
  • 一、路由首先需要配置路由,就是点击good组件进入goodDetail组件配置路由如下{path:goodDetail,component:goodDetail}同时在good组件中写入如下点击事件,路由中加入 ... [详细]
  • Vue基础一、什么是Vue1.1概念Vue(读音vjuː,类似于view)是一套用于构建用户界面的渐进式JavaScript框架,与其它大型框架不 ... [详细]
  • 网络请求模块选择——axios框架的基本使用和封装
    本文介绍了选择网络请求模块axios的原因,以及axios框架的基本使用和封装方法。包括发送并发请求的演示,全局配置的设置,创建axios实例的方法,拦截器的使用,以及如何封装和请求响应劫持等内容。 ... [详细]
  • uniapp开发H5解决跨域问题的两种代理方法
    本文介绍了uniapp开发H5解决跨域问题的两种代理方法,分别是在manifest.json文件和vue.config.js文件中设置代理。通过设置代理根域名和配置路径别名,可以实现H5页面的跨域访问。同时还介绍了如何开启内网穿透,让外网的人可以访问到本地调试的H5页面。 ... [详细]
  • 单页面应用 VS 多页面应用的区别和适用场景
    本文主要介绍了单页面应用(SPA)和多页面应用(MPA)的区别和适用场景。单页面应用只有一个主页面,所有内容都包含在主页面中,页面切换快但需要做相关的调优;多页面应用有多个独立的页面,每个页面都要加载相关资源,页面切换慢但适用于对SEO要求较高的应用。文章还提到了两者在资源加载、过渡动画、路由模式和数据传递方面的差异。 ... [详细]
  • 本文是一篇翻译文章,介绍了async/await的用法和特点。async关键字被放置在函数前面,意味着该函数总是返回一个promise。文章还提到了可以显式返回一个promise的方法。该特性使得async/await更易于理解和使用。本文还提到了一些可能的错误,并希望读者能够指正。 ... [详细]
  • 本文详细介绍了解决全栈跨域问题的方法及步骤,包括添加权限、设置Access-Control-Allow-Origin、白名单等。通过这些操作,可以实现在不同服务器上的数据访问,并解决后台报错问题。同时,还提供了解决second页面访问数据的方法。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 如何查询zone下的表的信息
    本文介绍了如何通过TcaplusDB知识库查询zone下的表的信息。包括请求地址、GET请求参数说明、返回参数说明等内容。通过curl方法发起请求,并提供了请求示例。 ... [详细]
  • 本文详细介绍了cisco路由器IOS损坏时的恢复方法,包括进入ROMMON模式、设置IP地址、子网掩码、默认网关以及使用TFTP服务器传输IOS文件的步骤。 ... [详细]
  • 在package.json中有如下两个对象:husky:{hooks:{pre-commit:lint-staged}},lint-staged:{src** ... [详细]
  • 微信民众号商城/小顺序商城开源项目介绍及使用教程
    本文介绍了一个基于WeiPHP5.0开发的微信民众号商城/小顺序商城的开源项目,包括前端和后端的目录结构,以及所使用的技术栈。同时提供了项目的运行和打包方法,并分享了一些调试和开发经验。最后还附上了在线预览和GitHub商城源码的链接,以及加入前端交流QQ群的方式。 ... [详细]
  • VUE中引用路径的配置
    在vue项目开发中经常引用JS、CSS、IMG文件。当项目较大时文件层级很多,导致路径很长,我们可以通过在bulidwebpack.base.conf.js设置简便的引用路径一、 ... [详细]
  • 【前端工具】nodejs+npm+vue 安装(windows)
    预备先看看这几个是干嘛的,相互的关系是啥。nodejs是语言,类比到php。npm是个包管理,类比到composer。vue是个框架&# ... [详细]
  • 使用这个技巧要达到的目标:一般来说,模型和控制器你都不会有相同的类名字。让我先创建一个取名为post的model。classPostextendsModel{}现在 ... [详细]
author-avatar
我没资格我不配
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有