对于需要大量使用 http 请求的项目,我们通常会选择对 http 请求的方法进行二次封装,以便增加统一的拦截器,或者统一处理阻止重复提交之类的逻辑。Vue.js 的项目中我们选择使用了 axios 这样一个 http 库,下面也就简述下基于 axios 做的简单二次封装

依赖
首先引入 axios ,对于 ie9 这样不支持 promise 的浏览器还需引入 es6-promise 模块
require('es6-promise').polyfill();
var axios = require('axios');
axios 初始化
初始化我们要实现两个需求:
1.发送请求时带上 cookies
2.重发发送请求时,如果前一次相同请求还未结束则中止前一次请求
const httpServer = axios.create({
responseType: 'json',
withCredentials: true, // 设置 withCredentials 使请求带上 `cookies`
cancelToken: new axios.CancelToken(function (c) {
cancel = c // 记录当前请求的取消方法
})
})
http 请求二次封装
var promiseArr = {} // 用于记录每个请求的取消方法
const gUtils = {
getData: function () {
let cancel
const httpServer = axios.create({
responseType: 'json',
withCredentials: true, // 设置 withCredentials 使请求带上 `cookies`
cancelToken: new axios.CancelToken(function (c) {
cancel = c // 记录当前请求的取消方法
})
})
// 设置一个拦截器,每次发起请求前取消掉在进行中的相同请求
httpServer.interceptors.request.use(function (config) {
if (promiseArr[config.url]) {
promiseArr[config.url]('操作取消')
promiseArr[config.url] = cancel
} else {
promiseArr[config.url] = cancel
}
return config
}, function (err) {
// return Promise.reject (error)
})
return httpServer
}
}
这样我们在对接服务时候直接使用我们封装好的 http 请求方法即可
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# axios
# http请求
# vue
# http
# Vue中Axios的封装与接口管理详解
# vue封装axios与api接口管理的完整步骤
# Vue+axios实现统一接口管理的方法
# vue中的axios配置及接口请求路径api配置
# Vue3引入axios封装接口的两种方法实例
# Vue路由切换和Axios接口取消重复请求详解
# axios接口管理优化操作详解
# 拦截器
# 也就
# 这样一个
# 还未
# 不支持
# 还需
# 大家多多
# 通常会
# 装好
# 重发
# 使用了
# url
# promise
# return
# brush
# require
# class
# polyfill
# pre
相关文章:
深圳网站制作培训,深圳哪些招聘网站比较好?
宝塔Windows建站如何避免显示默认IIS页面?
建站主机无法访问?如何排查域名与服务器问题
阿里云网站搭建费用解析:服务器价格与建站成本优化指南
建站主机服务器选型指南与性能优化方案解析
香港服务器租用费用高吗?如何避免常见误区?
表情包在线制作网站免费,表情包怎么弄?
建站主机选哪种环境更利于SEO优化?
建站之星官网登录失败?如何快速解决?
极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?
如何构建满足综合性能需求的优质建站方案?
建站之星安装提示数据库无法连接如何解决?
音响网站制作视频教程,隆霸音响官方网站?
电视网站制作tvbox接口,云海电视怎样自定义添加电视源?
如何通过宝塔面板实现本地网站访问?
如何快速建站并高效导出源代码?
如何破解联通资金短缺导致的基站建设难题?
为什么Go需要go mod文件_Go go mod文件作用说明
Dapper的Execute方法的返回值是什么意思 Dapper Execute返回值详解
建站之星下载版如何获取与安装?
打鱼网站制作软件,波克捕鱼官方号怎么注册?
如何基于PHP生成高效IDC网络公司建站源码?
山东云建站价格为何差异显著?
公司网站设计制作厂家,怎么创建自己的一个网站?
岳西云建站教程与模板下载_一站式快速建站系统操作指南
如何通过远程VPS快速搭建个人网站?
建站之星后台密码遗忘或太弱?如何重置与强化?
湖北网站制作公司有哪些,湖北清能集团官网?
在线制作视频的网站有哪些,电脑如何制作视频短片?
北京专业网站制作设计师招聘,北京白云观官方网站?
香港服务器选型指南:免备案配置与高效建站方案解析
制作网站公司那家好,网络公司是做什么的?
如何选择高性价比服务器搭建个人网站?
如何用wdcp快速搭建高效网站?
css网站制作参考文献有哪些,易聊怎么注册?
装修招标网站设计制作流程,装修招标流程?
如何在IIS服务器上快速部署高效网站?
高性能网站服务器配置指南:安全稳定与高效建站核心方案
建站上市公司网站建设方案与SEO优化服务定制指南
建站之星后台管理:高效配置与模板优化提升用户体验
动图在线制作网站有哪些,滑动动图图集怎么做?
建站之星云端配置指南:模板选择与SEO优化一键生成
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
C++中引用和指针有什么区别?(代码说明)
专业商城网站制作公司有哪些,pi商城官网是哪个?
定制建站流程解析:需求评估与SEO优化功能开发指南
制作门户网站的参考文献在哪,小说网站怎么建立?
如何通过免费商城建站系统源码自定义网站主题与功能?
黑客如何利用漏洞与弱口令入侵网站服务器?
深入理解Android中的xmlns:tools属性
*请认真填写需求信息,我们会在24小时内与您取得联系。