一文简单入门 Axios

Axios 是一个流行的基于 Promise 的请求,用于在浏览器或者 Node 环境中进行 HTTP 请求。它提供了简单易用的 API,可以发送各类请求,比如:GET、POST、PUT、DELETE等,并处理响应数据。Axios 在前端项目中被优先选择的概率很高,下面就用实际的例子来简单熟悉它,通过编写接口并且调用 Apifox 生成的 Mock 数据。

安装 Axios

要安装 Axios,前置条件是需要先下载 Node,然后在终端执行命令(以下都是以 npm 为例)

bash 复制代码
npm install axios

上面这种方式是局部安装的,会安装在项目的node_modules文件夹下。 我也比较推荐这种方式,因为该方式会将全局的 Axios 依赖和项目中的依赖隔离开,确保每个项目的 axios 依赖有自己的版本控制和依赖。当然如果想全局安装也是可以的,可以执行下面的命令:

bash 复制代码
npm i -g axios

安装完成后,你可以新建一个.js 的文件,用来发起 HTTP 请求,基本结构如下:

javascript 复制代码
import $http from 'axios'

// Mock服务,基础路径
const baseUrl = 'https://m1.apifoxmock.com/m1/593188-0-default';

// 查询指定 id 的宠物
$http.get(`${baseUrl}/pet/1`).then(res => {
  console.log('查询---》', res.data);
}).catch(err => {
  console.log('查询---》', err);
})

// 新增
$http.post(`${baseUrl}/pet`, {
  name: '太牛了',
  status: 'sold'
}).then(res => {
  console.log('新增---》', res.data);
}).catch(err => {
  console.log('新增---》', err);
})

// 修改
$http.put(`${baseUrl}/pet`, {
  name: 'test',
}).then(res => {
  console.log('修改---》', res.data);
}).catch(err => {
  console.log('修改---》', err);
})

// 删除
$http.delete(`${baseUrl}/pet/0`).then(res => {
  console.log('删除---》', res.data);
}).catch(err => {
  console.log('删除---》', err);
})

接口 Mock

为了方便测试,使用 Apifox 中的 Mock数据

发起请求

发起请求前,首先需要导入 Axios 库,然后可选的设置基础的 Mock 地址

javascript 复制代码
import $http from 'axios'

// Mock服务,基础路径 (到 Apifox 的云端Mock中找)
const baseUrl = 'https://m1.apifoxmock.com/m1/593188-0-default';

GET请求

示例:

javascript 复制代码
// 查询指定 id 的宠物
$http.get(`${baseUrl}/pet/1`).then(res => {
  console.log('查询---》', res.data);
}).catch(err => {
  console.log('查询---》', err);
})

响应如下:

POST请求

示例:

javascript 复制代码
// 新增
$http.post(`${baseUrl}/pet`, {
  name: '太牛了',
  status: 'sold'
}).then(res => {
  console.log('新增---》', res.data);
}).catch(err => {
  console.log('新增---》', err);
})

PUT 请求

示例:

javascript 复制代码
// 修改
$http.put(`${baseUrl}/pet`, {
  name: 'test',
}).then(res => {
  console.log('修改---》', res.data);
}).catch(err => {
  console.log('修改---》', err);
})

DELETE 请求

示例:

javascript 复制代码
// 删除
$http.delete(`${baseUrl}/pet/0`).then(res => {
  console.log('删除---》', res.data);
}).catch(err => {
  console.log('删除---》', err);
})

参考:

相关推荐
咬人喵喵19 小时前
植树节主题核心 SVG 交互玩法 + 品牌 / 账号案例 + 组件 / 教程
前端·css·编辑器·svg·e2编辑器
流星雨在线19 小时前
Apipost 和 Apifox 哪个更好用
apipost·apifox
Sailing19 小时前
🚀AI 写代码越来越快,但我开始不敢上线了
前端·后端·面试
Alair‎19 小时前
Vue 3 基础教程:从入门到精通
前端·javascript·vue.js
Sylvia33.19 小时前
体育数据API实战:用火星数据实现NBA赛事实时比分与状态同步
java·linux·开发语言·前端·python
码农阿豪19 小时前
Vue+Ant Design表格组件开发实战:从问题到优化的完整指南
前端·javascript·vue.js
QQ243919719 小时前
spring boot医院挂号就诊系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
用户693717500138419 小时前
OS级AI Agent:手机操作系统的下一个战场
android·前端·人工智能
百锦再19 小时前
Vue不是万能的:前后端不分离开发的优势
前端·javascript·vue.js·前端框架·vue
毕设源码_王学姐20 小时前
2026毕设ssm+vue民宿管理系统论文+程序
前端·vue.js·课程设计