目录
- 前言
- 一、什么是axios
- 定义
- 优点
- axios常用的API
- 二、axios发起GET请求
- 语法
- 基本使用
- 二、axios发起POST请求
- 语法
- 基本使用
- 三、直接使用axios发起请求
- 语法
- 基本使用
- 四、axios响应结果
- 五、axios的全局配置
- 六、axios拦截器
- 1、请求拦截器
- 2、响应拦截器
- 七、简单二次封装axios
- 为什么要二次封装axios
- 如何封装
- 1、导入axios
- 2、设置基础路径和请求超时时间
- 3、设置请求头数据格式
- 4、设置请求拦截器
- 5、设置响应拦截器
- 6、导出axios
- 完整代码
前言
axios是目前最为热门的ajax请求库,前端两大框架Vue和React官方都推荐使用axios发送ajax请求。
axios可以用在浏览器和 node.js 中,axios负责与后端交互,get、post后端接口信息,相当前后端的窗口。
一、什么是axios
定义
axios是一个基于promise的专门用于网络请求的库
官网:https://github.com/axios/axios
优点
① 相比于原生的XMLHttpRequest对象,axios简单易用
② 相比较于jQuery,axios更加轻量化
,只专注于网络数据请求
③ 支持浏览器和node.js
④ 支持Promise
⑤ 能拦截请求和响应
⑥ 自动转化JSON数据
axios常用的API
名称 | 说明 |
get | 查询数据 |
post | 添加数据 |
put | 修改数据 |
delete | 删除数据 |
二、axios发起GET请求
语法
data属性名称是固定的,用于获取后台响应的数据
axios.get('url',{params: paramsObj }).then(res=>{
console.log(res.data)
})
基本使用
// 请求的URL地址
var url = 'http://www.liulongbin.top:3006/api/get';
// 请求的参数对象
var paramsObj = { name: 'zs', age: 20 };
// 调用axios.get()函数发起get请求
axios.get(url, { params: paramsObj }).then(function (res) {
console.log(res.data)
})
二、axios发起POST请求
语法
axios.post('url', paramsObj).then(callback)
基本使用
// 请求的URL地址
var url = 'http://www.liulongbin.top:3006/api/post';
// 要提交服务器的数据
var dataObj = { address: '北京', location: '顺义区' };
// 调用axios.post()函数发起post请求
axios.post(url, dataObj).then(function (res) {
console.log(res.data)
})
三、直接使用axios发起请求
axios也提供了类似于jQuery中$.ajax()函数
params参数是路径参数,data参数是请求体参数
语法
axios({
method: '请求类型',
url: '请求的URL地址',
params: paramsData,
}).then(callback)
基本使用
// 发起GET请求
axios({
method: 'GET',
url: 'http://www.liulongbin.top:3006/api/get',
params: {name:'憨瓜',age:3}, // get参数要通过paramas属性提供
}).then(function (res) {
console.log(res.data)
})
// 发起POST请求
axios({
method: 'POST',
url: 'http://www.liulongbin.top:3006/api/post',
data: { // post数据要通过data属性提供
name: '娃哈哈',
age: 18,
gender: '女'
}
}).then(function (res) {
console.log(res.data)
})
四、axios响应结果
响应结果 | 说明 |
data | 实际响应回来的数据 |
header | 响应头信息 |
status | 响应状态码 |
statusText | 响应状态信息 |
五、axios的全局配置
超时时间
axios.defaults.timeout = 3000
默认地址
axios.defaults.baseURL= 'http://www.aaaaa.com'
设置请求头
axios.defaults.headers['mytoken']= 'aaadthbjuykjjyu'
六、axios拦截器
1、请求拦截器
在请求发出之前设置一些信息,主要处理请求token的统一注入问题
axios.interceptors.request.use(function(config){
// 在请求发出之前进行一些信息设置
// config是请求的配置信息,无论什么时候都需要return config,否则报错
return config;
},function(err){
// 处理响应错误的信息
})
2、响应拦截器
在获取数据之前对数据做一些加工处理,主要用于响应返回的数据异常和数据结构问题
axios.interceptors.response.use(function(config){
// 在这里对返回的函数进行处理
return res;
},function(err){
// 处理响应错误的信息
})
七、简单二次封装axios
为什么要二次封装axios
减少代码冗余,便于我们更好的管理API接口
如何封装
1、导入axios
import axios from "axios";
2、设置基础路径和请求超时时间
//利用axios对象的方法create,去创建一个axios实例
const service = axios.create({
//基础路径
baseURL:'/api',
//请求超时时间 (5s内没响应就失败了)
timeout:5000
})
3、设置请求头数据格式
大部分情况下,请求头都是固定的,只有少部分情况下,会需要一些特殊的请求头,当需要特殊请求头时,将特殊请求头作为参数传入覆盖基础配置
const service = axios.create({
//基础路径
baseURL:'/api',
//请求超时时间 (5s内没响应就失败了)
timeout:5000,
// 设置请求头数据格式
headers: {
get: {
'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8'
// 在开发中,一般还需要单点登录或者其他功能的通用请求头,可以一并配置进来
},
post: {
'Content-Type': 'application/json;charset=utf-8'
// 在开发中,一般还需要单点登录或者其他功能的通用请求头,可以一并配置进来
}
},
})
4、设置请求拦截器
设置请求拦截器:客户端发送请求 →【请求拦截器】→ 服务端接收
token校验(jwt)
【接收到服务器返回的token,将TA保存在本地存储里
,每一次请求的时候都应该给带上oken】
//请求拦截器
service.interceptors.request.use((config)=>{
// 假设我们把token存储到本地存储中的
let token = localStorage.getItem("token");
// token 如果存在就加在配置项的头部
token && (config.headers.Authorization = token);
// 请求成功的返回配置对象
return config
},(error)=>{
// 请求失败
return Promise.reject(error)
})
5、设置响应拦截器
响应拦截器:服务器返回信息 →【拦截的统一处理】→ 客户端js获取到信息
//响应拦截器
service.interceptors.response.use((response)=>{
//响应成功的返回
return response.data
},(error)=>{
// 响应失败
return Promise.reject(error)
})
6、导出axios
export default service;
完整代码
// 引入axios
import axios from "axios";
// 创建一个axios实例
const service = axios.create({
//基础路径
baseURL:'/api',
//请求超时时间 (5s内没响应就失败了)
timeout:5000,
// 设置请求头数据格式
headers: {
get: {
'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8'
// 在开发中,一般还需要单点登录或者其他功能的通用请求头,可以一并配置进来
},
post: {
'Content-Type': 'application/json;charset=utf-8'
// 在开发中,一般还需要单点登录或者其他功能的通用请求头,可以一并配置进来
}
},
})
//请求拦截器
service.interceptors.request.use((config)=>{
// 假设我们把token存储到本地存储中的
let token = localStorage.getItem("token");
// token 如果存在就加在配置项的头部
token && (config.headers.Authorization = token);
//请求成功的返回配置对象
return config
},(error)=>{
// 请求失败
return Promise.reject(error)
})
//响应拦截器
service.interceptors.response.use((response)=>{
//响应成功的返回
return response.data
},(error)=>{
//响应失败的返回
return Promise.reject(error)
})
//导出axios实例
export default service