Skip to content

Axios

一个基于 Promise 的网络请求库,可用于浏览器和 Node.js 环境。

安装

bash
npm install axios

使用

javascript
import axios from 'axios';

// 默认配置
const defaultConfig = {
  baseURL: 'https://example.com/api',
  timeout: 6e4,
  headers: {
    'Content-Type': 'application/json',
  }
};

// axios 实例
const http = axios.create(defaultConfig);

// 请求拦截器
http.interceptors.request.use((config) => {
  // 在发送请求之前做些什么
  return config;
}, (error) => {
  // 对请求错误做些什么
  return Promise.reject(error);
})

// 响应拦截器
http.interceptors.response.use((response) => {
  // 2xx 范围内的状态码都会触发该函数
  // 对响应数据做点什么
  return response;
}, (error) => {
  // 超出 2xx 范围的状态码都会触发该函数
  // 对响应错误做点什么
  return Promise.reject(error);
});

export default http;
javascript
import http from './http';

const params = {
  page: 1,
  size: 10,
};

http.get('/example', { params })
 .then((response) => {
    console.log(response.data);
  })
 .catch((error) => {
    console.log(error);
  });
javascript
import http from './http';

const data = {
  page: 1,
  size: 10,
};

http.post('/example', { data })
 .then((response) => {
    console.log(response.data);
  })
 .catch((error) => {
    console.log(error);
  });
javascript
import http from './http';

const data = new FormData();

data.append('file', file);

http.post('/upload', data, {
    headers: { 'Content-Type': 'multipart/form-data' }
  })
 .then((response) => {
    console.log(response.data);
  })
 .catch((error) => {
    console.log(error);
  });