Skip to content

lowcoding/lowcode-mock

Repository files navigation

title
文档

概述

mock & 代理 工具。

wdZFc6.gif

3.gif

安装

Install

yarn create @lowcoding/mock

Start

yarn start

mock server 默认在本地 3000 端口启动,访问 http://localhost:3000/ 即可。

lowcode-mock 默认支持跨域。

mock

src\routes 目录下新建一个 js 文件,将如下内容复制进去保存即可:

import KoaRouter from 'koa-router'
import proxy from '../middleware/Proxy'
import { delay } from '../lib/util'
let Mock = require('mockjs')
let Random = Mock.Random

const router = new KoaRouter()
router.get('/your-mock-api', (ctx) => {
	ctx.body = '你的第一个mock接口'
})
module.exports = router

已经内置了创建新 mock 的物料,在 vscode-lowcode 的区块功能中直接使用即可。

使用 vscode 插件 lowcode ,可直接根据 JSON 数据或者 YAPI 接口定义自动生成 mock 接口以及 mock 数据。

根据 YAPI 生成 mock

如何配置 vscode-lowcode,查看 文档

复制 YAPI 上接口 id ,比如 https://yapi.baidu.com/project/869/interface/api/14037 最后面的数字部分

wdZFc6.gif

根据 JSON 生成 mock

复制 JSON 数据,比如:

3.gif

通过 JSON 数据生成的 mock 接口需要手动修改路由地址。

根据字段类型或字段名称生成特定的 mock 数据

如下为默认的,按需要自行配置即可

200&&number 一处表示当需要 mock 的字段名为code,并且类型为number,mock 为固定值 200

延时

import KoaRouter from 'koa-router'
import proxy from '../middleware/Proxy'
import { delay } from '../lib/util'
let Mock = require('mockjs')
let Random = Mock.Random

const router = new KoaRouter()
router.get('/delay', (ctx) => {
	delay(3) // 3 秒后返回结果
	ctx.body = 'delay'
})

可用于测 loading 效果。

http 异常状态码

router.get('/httpError', (ctx) => {
	ctx.status = 401
	ctx.body = 'http 401'
})

代理

router.get('/proxy', proxy('https://github.com/wjkang/lowcode-mock'), (ctx) => {
	ctx.body = 'https://github.com/wjkang/lowcode-mock'
})

来自 /proxy 的请求转发到 https://github.com/wjkang/lowcode-mock/proxy ,用于后端接口可联调的时候跳过本地 mock,转发请求到后端接口。

router.all(new RegExp('^/lowcode/mock/(|^$)'), proxy('https://github.com/wjkang/lowcode-mock'))

不需要 mock 并且匹配正则的接口直接转发到后端地址。

拦截响应

.get('/intercept/response', async (ctx) => {
		const result = await request(ctx, 'http://localhost:3000/mock')
		const interceptResult = {
			...result.body,
			intercept: '拦截响应',
		}
		ctx.body = interceptResult
	})

可用于 mock 现有接口新增字段

Releases

No releases published

Packages

No packages published