前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >vite-plugin-mock使用

vite-plugin-mock使用

作者头像
wade
发布2022-04-27 16:18:21
2.1K0
发布2022-04-27 16:18:21
举报
文章被收录于专栏:coding个人笔记coding个人笔记
开发流程很多,不同公司都有自己的一套流程,甚至一套公司里面不同的组都有自己单独的开发流程。 对前端来说,很多情况静态页面写好了,接口给了字段,要是有模拟的数据,页面开发完成,对接的时候只需要稍微调整。

所以mock的存在可以节省很多的时间,只不过以前都没用过,因为后端也有很多工具,从来没有前端自己mock过。这次业务需要自己mock数据,所以就使用了一下,发现还挺好用的。

今天分享的是vite-plugin-mock,记录一下使用流程及一些用到的配置。

安装:
npm i  mockjs vite-plugin-mock -D
vite.config.ts 配置
import { UserConfigExport, ConfigEnv } from 'vite'

import { viteMockServe } from 'vite-plugin-mock'
import vue from '@vitejs/plugin-vue'

export default ({ command }: ConfigEnv): UserConfigExport => {
  return {
    plugins: [
      vue(),
      viteMockServe({
        mockPath: 'mock',
        localEnabled: command === 'serve',
      }),
    ],
  }
}
在根目录下新建mock文件夹,新建文件
import { MockMethod } from 'vite-plugin-mock';

const arr: any = [];
for (let index = 0; index < 20; index++) {
  arr.push({
    customer_name: 'wade',
    status_text: '登录成功',
    os: 'Windows 10',
    browser: 'Chrome(99.0.4844.51)',
    ip: '192.168.9.110',
    created: '2021-12-14 10:41:02',
    location: '局域网 局域网',
  });
}

const logList = {
  total: 31,
  page: 1,
  page_size: 20,
  list: arr,
};

const statusList = {
  data: [
    { label: '全部', value: 0 },
    { label: '待审核', value: 1 },
  ],
};

export default [
  {
    url: '/mock/api/getList',
    method: 'post',
    response: () => {
      return logList;
    },
  },
  {
    url: '/mock/api/getStatusList',
    method: 'get',
    response: () => {
      return statusList;
    },
  },
] as MockMethod[];

开发的时候这样就已经可以了,安装个axios,实验一下:

axios.get("/mock/api/getList").then((res) => {
  console.log(res);
});

接口的模拟请求就实现了。至于生产环境使用,我是觉得不可能会用到,就没研究了。

vite-plugin-mock实现其实就是本地启动了一个服务,然后进行一些数据和模拟请求的各个配置。好比我自己用node启动一个接口:

const http=require('http');

http.createServer(function(requset,response){
	response.setHeader('Access-Control-Allow-Credentials', 'true');
	response.setHeader('Access-Control-Allow-Origin', '*');
	setTimeout(() => {
		response.end('#test{color:red}');
	}, 3000);
}).listen(3001);

console.log('run port 3001')

只不过vite-plugin-mock用的是connect。get实现的接口,你可以复制出来在浏览器访问看看就明白了。

但是有一点没理解,项目启动代理的情况下,如果本地启动了一个mock接口,请求就会是本地启动的接口,如果本地没有,会被代理到设置的代理地址。我觉得是代理proxy实现的,没查到xhr会自动去实现这个功能。

所以开发的时候,服务器已经有的接口可以请求服务器,没有的接口自己模拟,当要联调的时候再去mock里面把地址改一下。

至于其它配置,可以去看看是否需要: vite-plugin-mock

tips

这边用的是npm init @vitejs/app创建项目,遇见了几个小问题

Cannot find module 'ws'

试了一下打包,结果报错了:

Cannot find module 'ws' or its corresponding type declarations.

看了一下,vite版本的^2.8.0,ws在devDependencies里面,自己安装了npm i --save-dev @types/ws就可以打包了。去GitHub提了个issue,才一个小时就关闭了,原来早就有人提了。

"import.meta" is not available

去vite官网看了一下: Vite 支持使用特殊的 import.meta.glob 函数从文件系统导入多个模块 这只是一个 Vite 独有的功能而不是一个 Web 或 ES 标准

vite-plugin-mock生产环境使用也建议使用 import.meta.glob功能来进行全部导入,但是我打印了一下是一个空对象。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2022-04-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 coding个人笔记 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 安装:
  • vite.config.ts 配置
  • 在根目录下新建mock文件夹,新建文件
  • tips
    • Cannot find module 'ws'
      • "import.meta" is not available
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档