vite-plugin-mock插件的3.0.2版本在生产环境无法使用

vite-plugin-mock

在开发中使用vite-plugin-mock插件时遇到生产环境中无法使用的问题,查看了github中提交的issues

发现原来不止我一个人遇到这种情况

后面我将3.0.2版本降级到2.9.6后才可以正常使用

安装

npm install mockjs@1.1.0 --save

npm install vite-plugin-mock@2.9.6 --save-dev

使用:

vite.config.ts

ts 复制代码
export default defineConfig(
  ({ command }) => {
    return {
      // ...其它配置,略
      plugins: [
        viteMockServe({
          ignore: /^\_/,//忽略以_开头的文件
          mockPath: 'mock',// mock文件的存放路径
          localEnabled: true,//是否启用本地模拟数据
          prodEnabled: true,//是否启用生产环境模拟数据
          injectCode: `
          import { setupProdMockServer } from '../mock/_createProductionServer'

          setupProdMockServer()
          `
        })
      ]
    }
  }
)

根目录中创建mock文件夹,设置mock接口

mock目录下创建_createProductionServer.ts文件

_createProductionServer.ts

ts 复制代码
import { createProdMockServer } from 'vite-plugin-mock/es/createProdMockServer'

import login from './login'

let mockModules: any[] = [...login]

export function setupProdMockServer() {
  createProdMockServer(mockModules)
}

登录接口示例

mock/login/index.ts

ts 复制代码
export default [
  {
    // 请求地址
    url: '/mock/api/login',
    // 请求方式
    method: 'post',
    // 模拟接口返回数据
    response: ({ body }) => {
      if (body.username !== 'admin' || body.password !== 'admin') {
        return { code: 400, message: '用户名或密码错误' }
      }
      return {
        access_token: 'token',
        token_type: 'Bearer',
      }
    }
  }
]
相关推荐
饼饼饼10 小时前
React19 状态解惑:State 没那么神秘,一文读懂 React 状态不可变原则与 Hooks 底层链表
前端·react.js
難釋懷11 小时前
Nginx获取客户端真实IP
服务器·前端·nginx
甲维斯11 小时前
GLM5.2超过Opus4.8Think,全球第二了!
前端·人工智能·ai编程
by————组态11 小时前
Ricon组态系统 - 新一代Web可视化组态平台
前端·后端·物联网·架构·组态·组态软件
JieE21211 小时前
手把手带你用纯 CSS 实现一个 3D 旋转魔方,这些前端基础你能打几分?
前端·css·html
lichenyang45311 小时前
鸿蒙 Web 容器(二):H5 和 ArkTS 说话前,先定一份「协议」
前端
JYeontu11 小时前
开箱流水加载动画
前端·javascript·css
RANxy11 小时前
AntV 入门系列:G6 图可视化实战
前端
尽欢i11 小时前
Vue3 customRef 封神教程:防抖、本地存储、自动埋点一套搞定,模板干干净净
前端·javascript·vue.js