Axios 是一个基于 Promise 的 HTTP 客户端,可用于浏览器和 Node.js 环境。以下是它的一些主要作用:
浏览器环境
- 发起 HTTP 请求
Axios 能轻松发起多种类型的 HTTP 请求,像 GET、POST、PUT、DELETE 等。借助这些请求,你可以与服务器进行数据交互。例如,从服务器获取数据或者向服务器提交数据。
javascript
// 发起 GET 请求
axios.get('https://api.example.com/data')
.then(response => {
console.log(response.data);
})
.catch(error => {
console.error(error);
});
// 发起 POST 请求
axios.post('https://api.example.com/submit', {
name: 'John',
age: 30
})
.then(response => {
console.log(response.data);
})
.catch(error => {
console.error(error);
});
- 拦截请求和响应
Axios 允许你在请求发送之前和响应返回之后进行拦截,以此添加额外的处理逻辑。例如,在请求头中添加认证信息,或者对响应数据进行统一处理。
javascript
// 请求拦截器
axios.interceptors.request.use(config => {
// 在发送请求之前做些什么
config.headers.Authorization = 'Bearer your_token';
return config;
}, error => {
// 对请求错误做些什么
return Promise.reject(error);
});
// 响应拦截器
axios.interceptors.response.use(response => {
// 对响应数据做点什么
return response.data;
}, error => {
// 对响应错误做点什么
return Promise.reject(error);
});
- 转换请求和响应数据
可以对发送的数据和接收的数据进行转换。例如,将发送的数据转换为 JSON 格式,或者将接收的 JSON 数据转换为 JavaScript 对象。
javascript
axios.post('https://api.example.com/submit', {
name: 'John',
age: 30
}, {
transformRequest: [function (data, headers) {
// 对 data 进行任意转换处理
return JSON.stringify(data);
}],
transformResponse: [function (data) {
// 对 data 进行任意转换处理
return JSON.parse(data);
}]
})
- 取消请求
在某些情况下,你可能需要取消已经发起的请求。Axios 提供了取消请求的功能。
javascript
const CancelToken = axios.CancelToken;
const source = CancelToken.source();
axios.get('https://api.example.com/data', {
cancelToken: source.token
})
.then(response => {
console.log(response.data);
})
.catch(thrown => {
if (axios.isCancel(thrown)) {
console.log('Request canceled', thrown.message);
} else {
console.error(thrown);
}
});
// 取消请求
source.cancel('Operation canceled by the user.');
Node.js 环境
- 服务器端数据交互
在 Node.js 服务器端,Axios 可用于与其他服务器进行数据交互。例如,调用第三方 API 获取数据。
javascript
const axios = require('axios');
axios.get('https://api.example.com/data')
.then(response => {
console.log(response.data);
})
.catch(error => {
console.error(error);
});

- 代理服务器
可以使用 Axios 构建代理服务器,将客户端的请求转发到其他服务器,并将响应返回给客户端。
总的来说,Axios 提供了简洁、灵活且强大的 API,能让开发者方便地处理 HTTP 请求,在前后端开发中都被广泛应用。