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',
      }
    }
  }
]
相关推荐
zhongjiahao1 小时前
一文带你了解前端全局状态管理
前端
柳安1 小时前
对keep-alive的理解,它是如何实现的,具体缓存的是什么?
前端
keyV1 小时前
告别满屏 v-if:用一个自定义指令搞定 Vue 前端权限控制
前端·vue.js·promise
X_Eartha_8151 小时前
前端学习—HTML基础语法(1)
前端·学习·html
如果你好1 小时前
一文搞懂事件冒泡与阻止方法:event.stopPropagation() 实战指南
前端·javascript
用户8168694747251 小时前
深入 useMemo 与 useCallback 的底层实现
前端·react.js
AAA简单玩转程序设计1 小时前
救命!Java 进阶居然还在考这些“小儿科”?
java·前端
MediaTea1 小时前
思考与练习(第十章 文件与数据格式化)
java·linux·服务器·前端·javascript
JarvanMo1 小时前
别用英语和你的大语言模型说话
前端
江公望1 小时前
Vue3的 nextTick API 5分钟讲清楚
前端·javascript·vue.js