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

网络请求模块选择——axios框架的基本使用和封装

本文介绍了选择网络请求模块axios的原因,以及axios框架的基本使用和封装方法。包括发送并发请求的演示,全局配置的设置,创建axios实例的方法,拦截器的使用,以及如何封装和请求响应劫持等内容。

上一篇:【Vuejs进阶版】

文章目录

  • 一、为什么选择 axios?
  • 二、axios框架的基本使用
  • 三、axios发送并发请求
    • 1、发送 get 请求演示:
    • 2、发送两个请求并发执行
    • 4、全局配置
  • 四、axios 的实例
    • 1、为什么要创建 axios 的实例(instance)
  • 五、如何使用拦截器
  • 六、axios封装和请求响应劫持


一、为什么选择 axios?

axios = ajax i/o system

  • 在浏览器中发送 XMLHttpRequests 请求
  • 在 node.js 环境中发送 http 请求
  • 支持 Promise API
  • 拦截请求和相应
  • 转换请求和相应数据
  • 等等

axios 支持多种请求方式:

  • axios(config)
  • axios.request(config)
  • axios.get(url,[,config])
  • axios.delete(url,[,config])
  • axios.head(url,[,config])
  • axios.post(url[,data[,[,config]]))
  • axios.put(url[,data[,config]])
  • axios.patch(url[,data[,config]])

二、axios框架的基本使用
  1. vue init webpack learnaxios:创建vue项目
  2. npm install axios@0.18.0 --save:安装axios【cd到相关目录下】
  3. import导入
    在这里插入图片描述

三、axios发送并发请求

1、发送 get 请求演示:

在这里插入图片描述

2、发送两个请求并发执行


  • 第一种方法:使用axios.all,可以存放多个数组
    在这里插入图片描述
  • 第二种方法:axios.all([])返回的结果是一个数组,使用axios.spread可将数组[res1,res2]展开为 res1,res2
    在这里插入图片描述

4、全局配置

开发中,可能很多参数都是固定的,这个时候我们可以进行一些抽取,也可以利用 axios 的全局配置
在这里插入图片描述
常见的配置选项:
在这里插入图片描述

四、axios 的实例

1、为什么要创建 axios 的实例(instance)


  • 当我们从 axios 模块中导入对象时,使用的实例是默认的实例
  • 当给该实例设置一些默认配置时,这些配置就被固定下俩了
  • 但是后续开发中,某些配置可能会不太一样
  • 比如某些请求需要使用特定的 baseURL 或者 timeout 或者 content-Type 等
  • 这个时候,我们就可以创建新的实例,并且传入属于该实例的配置信息
    请添加图片描述

五、如何使用拦截器

请求成功、请求拦截
响应成功、响应拦截
在这里插入图片描述

六、axios封装和请求响应劫持

做拦截处理

1、安装axios

npm install axios --save

2、创建模拟的配置文件
新建文件:src\config\index.js

export default{title:"elm",baseUrl:{dev:"http://localhost:3000", //开发的时候后台接口的地址pro:"" // 上线产品发布之后,后台接口的地址 }
}

3、使用axios做ajax请求

新建文件:src\api\axios.js

import axios from 'axios'
import config from '@/config'// 判断node的开发模式
const baseUrl = process.env.NODE_ENV === 'developent' ? config.baseUrl.dev : config.baseUrl.pro
console.log(process.env.NODE_ENV);
class HttpRequest{// 配置要请求的URL地址constructor(baseUrl){this.baseUrl = baseUrl// 对请求队列进行处理this.queue={}}// 设置很多的配置getInsideConfig(){const config = {baseURL:this.baseUrl,header:{// 请求头的配置}}return config}// 做一个拦截interceptors(请求实例,url)interceptors(instance,url){// 拦截请求instance.interceptors.request.use((config)=>{// 处理config,判断是否是所有的拦截都会通过这里console.log('拦截和处理请求');console.log(config);return config;})// 拦截响应instance.interceptors.reponse.use((res)=>{// 处理响应console.log('处理响应');console.log(res);return res.data;},(error)=>{// 请求出问题,处理问题console.log(error);return {error:"网络出错了"}})}request(options){const instance = axios.create() //创造实例对象// 与上文getInsideConfig()形成呼应,options会覆盖掉this.getInsideConfigoptions = Object.assign(this.getInsideConfig(),options)// 进行数据劫持this.interceptors(instance,options.url)return instance(options)}}
// 实例化拦截对象
const axiosObj = new HttpRequest(baseUrl)
// 导出
export default axiosObj

新建文件:src\api\data.js

// 对外做ajax请求
import axios from '@/api/axios'export const getBannerData = ()=>{return axios.request({url:"banner",methods: 'get'})
}

测试:

views\Home.vue文件中

<template><div class&#61;"home"><h1>HOME</h1></div>
</template><script>
// &#64; is an alias to /src
import HelloWorld from &#39;&#64;/components/HelloWorld.vue&#39;
import {getBannerData} from &#39;&#64;/api/data&#39;export default {name: &#39;Home&#39;,components: {HelloWorld},async mounted(){let result &#61; await getBannerData()console.log(result);}
}
</script>

运行elm项目&#xff1a;npm run serve
模拟编写后端数据&#xff0c;供前端使用
elm同级新建elmserve/index.js文件&#xff0c;内容如下&#xff1a;

let express &#61; require(&#39;express&#39;)
let app &#61; express()// 解决跨域问题
app.use((req,res,next)&#61;>{res.append(&#39;Access-Control-Allow-Origin&#39;,&#39;*&#39;)res.append(&#39;Access-Control-Allow-headers&#39;,&#39;*&#39;)next()
})app.get(&#39;/&#39;,(req,res)&#61;>{res.json({msg:"这是首页"})
})app.get(&#39;/banner&#39;,(req,res)&#61;>{res.json({msg:"这是banner"})
})app.listen(3000,()&#61;>{console.log(&#39;http://localhost:3000&#39;);
})

下一篇&#xff1a;【Vue项目开发】


推荐阅读
  • 本文探讨了2019年前端技术的发展趋势,包括工具化、配置化和泛前端化等方面,并提供了详细的学习路线和职业规划建议。 ... [详细]
  • 本文探讨了浏览器的同源策略限制及其对 AJAX 请求的影响,并详细介绍了如何在 Spring Boot 应用中优雅地处理跨域请求,特别是当请求包含自定义 Headers 时的解决方案。 ... [详细]
  • 本文深入探讨了HTTP请求和响应对象的使用,详细介绍了如何通过响应对象向客户端发送数据、处理中文乱码问题以及常见的HTTP状态码。此外,还涵盖了文件下载、请求重定向、请求转发等高级功能。 ... [详细]
  • 本文将详细探讨Linux pinctrl子系统的各个关键数据结构,帮助读者深入了解其内部机制。通过分析这些数据结构及其相互关系,我们将进一步理解pinctrl子系统的工作原理和设计思路。 ... [详细]
  • PHP 过滤器详解
    本文深入探讨了 PHP 中的过滤器机制,包括常见的 $_SERVER 变量、filter_has_var() 函数、filter_id() 函数、filter_input() 函数及其数组形式、filter_list() 函数以及 filter_var() 和其数组形式。同时,详细介绍了各种过滤器的用途和用法。 ... [详细]
  • 本文详细探讨了HTML表单中GET和POST请求的区别,包括它们的工作原理、数据传输方式、安全性及适用场景。同时,通过实例展示了如何在Servlet中处理这两种请求。 ... [详细]
  • 解决FCKeditor应用主题后上传问题及优化配置
    本文介绍了在Freetextbox收费后选择FCKeditor作为替代方案时遇到的上传问题及其解决方案。通过调整配置文件和调试工具,最终解决了上传失败的问题,并对相关配置进行了优化。 ... [详细]
  • Kubernetes 持久化存储与数据卷详解
    本文深入探讨 Kubernetes 中持久化存储的使用场景、PV/PVC/StorageClass 的基本操作及其实现原理,旨在帮助读者理解如何高效管理容器化应用的数据持久化需求。 ... [详细]
  • 在高并发需求的C++项目中,我们最初选择了JsonCpp进行JSON解析和序列化。然而,在处理大数据量时,JsonCpp频繁抛出异常,尤其是在多线程环境下问题更为突出。通过分析发现,旧版本的JsonCpp存在多线程安全性和性能瓶颈。经过评估,我们最终选择了RapidJSON作为替代方案,并实现了显著的性能提升。 ... [详细]
  • 深入剖析JVM垃圾回收机制
    本文详细探讨了Java虚拟机(JVM)中的垃圾回收机制,包括其意义、对象判定方法、引用类型、常见垃圾收集算法以及各种垃圾收集器的特点和工作原理。通过理解这些内容,开发人员可以更好地优化内存管理和程序性能。 ... [详细]
  • 当unique验证运到图片上传时
    2019独角兽企业重金招聘Python工程师标准model:public$imageFile;publicfunctionrules(){return[[[na ... [详细]
  • 本文探讨了如何通过一系列技术手段提升Spring Boot项目的并发处理能力,解决生产环境中因慢请求导致的系统性能下降问题。 ... [详细]
  • JavaScript:简洁与复杂之间的平衡
    本文探讨了在编写JavaScript教程时,如何在保持内容简洁的同时,确保初学者能够理解并应用实际开发中的复杂问题。文章通过具体示例分析了不同层次的JavaScript代码实现。 ... [详细]
  • 本文探讨了Web开发与游戏开发之间的主要区别,旨在帮助开发者更好地理解两种开发领域的特性和需求。文章基于作者的实际经验和网络资料整理而成。 ... [详细]
  • 本文将介绍如何利用Python爬虫技术抓取国内主流在线学习平台的数据,并以51CTO学院为例,进行详细的技术解析和实践操作。 ... [详细]
author-avatar
手机用户2602916737
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有