vue3 使用 mock 模拟服务器接口

文章目录

    • [1. 安装相应的包](#1. 安装相应的包)
    • [2. 创建相关文件](#2. 创建相关文件)
    • [3. 构建请求](#3. 构建请求)
    • 注意

axios-mock-adapter

在前端开发中,需要模拟请求或者数据来做一些简单的调试,这里可以使用mock来模拟服务器接口;

1. 安装相应的包

这里需要安装两个包,一个是axios,一个是axios-mock-adapter

项目安装后,首先在cmd中安装:

shell 复制代码
npm install axios
npm install axios-mock-adapter --save-dev

2. 创建相关文件

在src目录下创建mock文件夹,然后在mock文件夹中放置两个文件,一个server.ts,一个index.ts

很明显我们是在server.ts中构造请求,在index.ts中暴露;

server.ts代码内容如下:

ts 复制代码
import axios from 'axios'
import MockAdapter from 'axios-mock-adapter'

export default {
  bootstrap() {
    var mock = new MockAdapter(axios)
    // 在这里写构造请求
  }
}

index.ts代码内容如下:

ts 复制代码
import mock from './server'
export default mock

main.ts中添加两行:

ts 复制代码
import mock from './mock'
mock.bootstrap()

3. 构建请求

注意replay返回的是一个数组就好了

Get

无参数:

ts 复制代码
mock.onGet("/users").reply(200, {
  users: [{ id: 1, name: "John Smith" }],
});

axios.get("/users").then(function (response) {
  console.log(response.data);
});

有参数:

ts 复制代码
mock.onGet("/users", { params: { searchText: "John" } }).reply(200, {
  users: [{ id: 1, name: "John Smith" }],
});

axios
  .get("/users", { params: { searchText: "John" } })
  .then(function (response) {
    console.log(response.data);
  });

Post

ts 复制代码
mock.onPost('/api/user/info').reply(function (config){
      console.log(config)
      return [200, {status: 'success'}]
    })

axios.post('/api/user/info', {user:123, password:123}).then(res=>console.log(res))

注意

在搭配axios使用mock时,如果需要对axios进行二次封装,那mock就不应该使用axios,而是使用新封装的玩意进行处理;

ts 复制代码
// 假设二次封装后为request
import request from './utils/request'

// mock操作 var mock = new MockAdapter(request)
var mock = new MockAdapter(request)

这样就可以避免request请求后老是报错的问题;

相关推荐
sdm0704272 小时前
yum和开发工具vim/gcc
linux·服务器·centos
zhaoyufei1332 小时前
RK3568-11.0 设置WiFi p2p静态IP
服务器·tcp/ip·p2p
用户69371750013846 小时前
Google 正在“收紧侧加载”:陌生 APK 安装或需等待 24 小时
android·前端
蓝帆傲亦6 小时前
Web 前端搜索文字高亮实现方法汇总
前端
用户69371750013846 小时前
Room 3.0:这次不是升级,是重来
android·前端·google
漫随流水7 小时前
旅游推荐系统(view.py)
前端·数据库·python·旅游
踩着两条虫8 小时前
VTJ.PRO 核心架构全公开!从设计稿到代码,揭秘AI智能体如何“听懂人话”
前端·vue.js·ai编程
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ9 小时前
Linux 查询某进程文件所在路径 命令
linux·运维·服务器
jzlhll1239 小时前
kotlin Flow first() last()总结
开发语言·前端·kotlin
用头发抵命10 小时前
Vue 3 中优雅地集成 Video.js 播放器:从组件封装到功能定制
开发语言·javascript·ecmascript