Vue项目使用mockjs模拟后端接口

文章目录

    • 操作步骤
      • [1. 安装 mockjs 和 vite-plugin-mock](#1. 安装 mockjs 和 vite-plugin-mock)
      • [2. 安装 axios](#2. 安装 axios)
      • [3. 创建mock路径](#3. 创建mock路径)
      • [4. 配置 viteMockConfig](#4. 配置 viteMockConfig)
      • [5. 编写第一个mock接口](#5. 编写第一个mock接口)
      • [6. 创建 createProdMockServer](#6. 创建 createProdMockServer)
      • [7. 配置 axios](#7. 配置 axios)
      • [8. 编写请求接口](#8. 编写请求接口)
      • [9. 在页面中使用](#9. 在页面中使用)

操作步骤

1. 安装 mockjs 和 vite-plugin-mock

vite-plugin-mock 是 vite 提供的mock插件,配合mockjs 一起使用,比较方便。

复制代码
npm install mockjs vite-plugin-mock=2.9.6

2. 安装 axios

通过axios发送请求,请求到mock的模拟接口

复制代码
npm install axios

3. 创建mock路径

src 文件夹下创建 mock 文件夹,作为后续编写mock接口的路径

4. 配置 viteMockConfig

在 vite.config.js 中配置 viteMockConfig

mockPath 就是mock文件夹的路径

js 复制代码
import { defineConfig } from 'vite'
import {viteMockServe} from 'vite-plugin-mock'

// https://vitejs.dev/config/
export default defineConfig({
  plugins: [
    vue(),
    vueDevTools(),
    viteMockServe({
      mockPath: './src/mock'
    })
  ],
  resolve: {
    alias: {
      '@': fileURLToPath(new URL('./src', import.meta.url))
    }
  }
})

5. 编写第一个mock接口

mock文件夹下新建一个 js 文件,如user.js ,作为专门编写与用户相关的接口数据,内容如下:

js 复制代码
export default[
    {
        url: '/mock/user/test',
        method: 'get',
        response: () => {
            return {
                code: 200,
                msg: 'ok',
                data: 'hello world'
            }
        }
    }
]

该文件创建了一个模拟接口,地址为/mock/user/test

6. 创建 createProdMockServer

mock文件夹下创建一个index.js 文件,内容如下:

js 复制代码
import {createProdMockServer} from 'vite-plugin-mock/es/createProdMockServer'
// 导入上面写的user.js
import userModule from './user'

export function setupProdMockServer(){
    createProdMockServer([
        ...userModule
    ])
}

7. 配置 axios

创建 src/utils/system/request.js 文件用来全局配置axios,内容如下:

js 复制代码
// 在这个文件中配置axios,以及拦截请求
import axios from 'axios'

// const baseURL = import.meta.env.VITE_BASE_URL

const service = axios.create({
    bbaseURL: '/mock',
    timeout: 5000
})

// 拦截器,错误处理配置


export default service

8. 编写请求接口

创建src/api/user.js 文件作为请求用户相关数据的文件,内容如下:

js 复制代码
// 导入配置过的 axios
import request from '@/utils/system/request'

export function loginApi(data){
    return request({
        url: '/user/test',
        method: 'get',
        baseURL: '/mock',
        data
    })
}

该文件创建了一个请求接口loginAPi ,用来请求之前创建的mock接口地址

9. 在页面中使用

首先在需要的页面导入请求的接口:

js 复制代码
import { loginApi } from "../../api/user.js";

然后以Promise的形式使用

js 复制代码
onMounted(() => {
  loginApi({}).then(res => {
    console.log(res)
  })
})

如果控制台打印出结果,则说明配置成功

相关推荐
Warren985 小时前
Lua 脚本在 Redis 中的应用
java·前端·网络·vue.js·redis·junit·lua
mCell5 小时前
JavaScript 运行机制详解:再谈 Event Loop
前端·javascript·浏览器
amy_jork7 小时前
npm删除包
开发语言·javascript·ecmascript
帧栈9 小时前
开发避坑指南(27):Vue3中高效安全修改列表元素属性的方法
前端·vue.js
max5006009 小时前
基于桥梁三维模型的无人机检测路径规划系统设计与实现
前端·javascript·python·算法·无人机·easyui
我命由我1234510 小时前
软件开发 - 避免过多的 if-else 语句(使用策略模式、使用映射表、使用枚举、使用函数式编程)
java·开发语言·javascript·设计模式·java-ee·策略模式·js
萌萌哒草头将军10 小时前
Node.js v24.6.0 新功能速览 🚀🚀🚀
前端·javascript·node.js
AALoveTouch11 小时前
大麦APP抢票揭秘
javascript
持久的棒棒君12 小时前
启动electron桌面项目控制台输出中文时乱码解决
前端·javascript·electron
小小愿望14 小时前
移动端浏览器中设置 100vh 却出现滚动条?
前端·javascript·css