本文主要是介绍day39-测试平台搭建之前端vue学习-axios,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
一、json-server的使用
1.1.安装
npm install-g json-server
1.2.运行
json-server--watchdb.json
二、使用
2.1.axios是什么?
1).前端最流行的ajax请求库
2).react/vue官方都推荐使用axios发ajax请求
3).文档:https://github.com/axios/axios
2.2.axios特点
1).基于xhr+promise的异步ajax请求库
2).浏览器端/node端都可以使用
3).支持请求/响应拦截器
4).支持请求取消
5).请求/响应数据转换
6).批量发送多个请求
2.3.axios常用语法
1).axios(config):通用/最本质的发任意类型请求的方式
2).axios(urlL,config]):可以只指定url发get请求
3).axios.request(config):等同于axios(config)
4).axios.get(url[,config]):发get请求
5).axios.delete(url[,config]):发delete请求
6).axios.post(url[,data,config]):发post请求
7).axios.put(uri[,data,configl):发put 请求
8).axios.defaults.xxx:请求的默认全局配置
9).axios.interceptors.request.use():添加请求拦截器
10).axios.interceptors.response.use():添加响应拦截器
11).axios.create([config]):创建一个新的axios(它没有下面的功能)
12).axios.Cancel):用于创建取消请求的错误对象
13).axios.CancelToken():用于创建取消请求的token对象
14).axios.isCancel():是否是一个取消请求的错误4
15).axios.all(promises):用于批量执行多个异步请求
16).axios.spread():用来指定接收所有成功数据的回调函数的方法
2.4.axios.create(config)
1).根据指定配置创建一个新的axios,也就就每个新axios都有自己的配置
2).新axios只是没有取消请求和批量发请求的方法,其它所有语法都是一致的
2.5.拦截器函数/ajax请求/请求的回调函数的调用顺序
1).说明:调用axios()并不是立即发送ajax请求,而是需要经历一个较长的流程
2).流程:请求拦截器2=)请求拦截器1=>发ajax请求=>响应拦截器1=>响应拦截器2=>请求的回调
3).注意:此流程是通过promise串连起来的,请求拦截器传递的是config,响应拦截器传递的是response
2.6.取消请求
1).配置cancelToken对象
2).缓存用于取消请求的cancel函数
3).在后面特定时机调用cancel函数取消请求
4).在错误回调中判断如果error是cancel,做相应处理
三、axios源码分析
3.1.源码目录结构
3.2.axios与Axios的关系?
1).从语法上来说:axios不是Axios的实例
2).从功能上来说:axios是Axios的实例
3).axios是Axios.prototype.request函数bind()返回的函数
4).axios作为对象有Axios原型对象上的所有方法,有Axios对象上所有属性
3.3.instance与axios的区别?
1).相同
1.1).都是一个能发任意请求的函数:request(config)
1.2).都有发特定请求的各种方法:get()/post()/put()/delete()
1.3).都有默认配置和拦截器的属性:defaults/interceptors
2).不同
2.1).默认配置很可能不一样
2.2).instance没有axios后面添加的一些方法:create()/CancelToken()/all()
3.4.axios运行的整体流程
1).
2).整体流程:request(config)==>dispatchRequest(config)==>xhrAdapter(config)
2.1).request(config):将请求拦截器/dispatchRequest()/响应拦截器通过promise链串连起来,返回promise
2.2).dispatchRequest(config):转换请求数据===)调用xhrAdapter()发请求===>请求返回后转换响应数据.返回promise
2.3).xhrAdapter(config):创建XHR对象,根据config进行相应设置,发送特定请求,并接收响应数据,返回promise
3.5.axios的请求/响应拦截器是什么?
1).
2).请求拦截器
2.1).在真正发送请求前执行的回调函数
2.2).可以对请求进行检查或配置进行特定处理
2.3).成功的回调函数,传递的默认是config(也必须是)
2.4).失败的回调函数,传递的默认是error
3).响应拦截器
3.1).在请求得到响应后执行的回调函数
3.2).可以对响应数据进行特定处理
3.3).成功的回调函数,传递的默认是response
3.4).失败的回调函数,传递的默认是error
3.6.axios的请求/响应数据转换器是什么?
1).请求转换器:对请求头和请求体数据进行特定处理的函数
2).响应转换器:将响应体json字符串解析为js对象或数组的函数
3.7.response的整体结构
1).data
2).status
3).statusText
4).headers
5).onfig
6).request
3.8.error的整体结构4
1).message
2).response
3).request
3.9.如何取消未完成的请求?
1).当配置了cancelToken对象时,保存cancel函数
1.1).创建一个用于将来中断请求的cancelPromise
1.2).并定义了一个用于取消请求的cancel函数
1.3).将cancel函数传递出来
2).调用cancel()取消请求
2.1).执行cacel函数,传入错误信息message
2.2).内部会让cancelPromise变为成功,且成功的值为一个Cancel对象
2.3).在cancelPromise的成功回调中中断请求,并让发请求的proimse失败,失败的reason为Cancel对象
代码链接:ajax_promise_axios: ajax_promise_axios三个练习代码
这篇关于day39-测试平台搭建之前端vue学习-axios的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!