全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

详解基于 axios 的 Vue 项目 http 请求优化

对于需要大量使用 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小时内与您取得联系。