跳到主要内容

数据模拟 Mock

在前后端分离的开发中,Mock 数据是前端开发中很重要的一个环节,前端可以不必强依赖后端接口,只需要约定好对应的数据接口,前端可以通过 Mock 模拟数据先行开发,在后端接口开发完成后,只需要切换对应的接口地址即可,可以保证项目的同步开发。

ice.js 提供了开箱即用的 Mock 方案,支持 CRUD 等操作,在启动本地调试时会自动启用 Mock 服务。

目录约定

只需要在项目目录下新建 /mock 目录,并增加 jsts 文件作为 mock 服务文件。比如有以下的目录结构:

├── mock
| ├── index.ts
| └── user.ts
├── src
└── package.json

mock 目录下的 index.tsuser.ts 会被识别为 Mock 服务文件。

如果某些文件不需要被 mock 服务解析,可以通过工程配置进行自定义:

ice.config.mts
import { defineConfig } from '@ice/app';

export default defineConfig(() => ({
mock: {
// 忽略 mock 目录中 custom 目录下的文件以及 api.ts 文件
exclude: ["custom/**", "api.ts"]
},
}));

编写 Mock 接口

在 mock 服务文件中写入以下代码:

./mock/user.ts
export default {
'GET /api/users': [
{ name: 'foo', id: 0 },
{ name: 'bar', id: 1 },
],
}

启动调试服务后,假设启动的端口是 3000,直接在浏览器里访问 http://127.0.0.1:3000/api/users 即可看到接口返回数据。

请求方法

默认支持 GET, POST, PUT, DELETE, PATCH, HEAD, OPTIONS 请求方法。示例代码如下:

export default {
// 当 HTTP 请求方法是 GET,可以省略请求方法
'/api/users': [{ name: 'foo', id: 1 }, { name: 'bar', id: 2 }],
// 等同于上面的写法
'GET /api/users': [{ name: 'foo', id: 1 }, { name: 'bar', id: 2 }],

'POST /api/user': { users: [1, 2] },

'DELETE /api/users/1': { name: 'foo' },
}

返回值

返回值支持 StringArrayObject 类型。比如:

export default {
// 返回值是 String 类型
'GET /api/name': 'foo',
// 返回值 Array 类型
'POST /api/users': [
{ name: 'foo', id: 0 },
{ name: 'bar', id: 1 },
],
// 返回值是 Object 类型
'DELETE /api/users/1': { name: 'bar', id: 1 },
}

除此以外,还可以使用函数的形式来计算返回值,这在需要动态返回接口数据时很有用,如:

import type { Request, Response } from '@ice/app';

export default {
'POST /api/users/:id': (request: Request, response: Response) => {
const { id } = request.params;
response.send({ id: id });
},
}

关闭 Mock

当后端接口开发完成以后。此时可以通过以下命令关闭 Mock 服务:

# 关闭 Mock 服务
$ npm run start -- --no-mock

这样我们可以请求到后端返回的数据了。

使用 Mock.js

Mock.js 是一个随机生成 mock 数据的工具库,可以帮助我们快速生成随机的模拟数据。

import Mock from 'mockjs';

export default {
'GET /api/list': (req, res) => {
const list = Mock.mock({
'list|1-10': [
{
'id|+1': 1,
},
],
});
res.send({
status: 'SUCCESS',
data: {
list,
}
});
},
};

完整的语法请参考 Mock.js 文档

处理请求数据

如果用户希望使用一些中间件来处理请求的数据(req 对象),可以参考以下的示例代码:

import bodyParser from 'body-parser';
import type { Request, Response } from 'express';

export default {
'POST /api/login': (req: Request, res: Response) => {
bodyParser.json({ limit: '5mb', strict: false })(req, res, () => {
console.log(req.body);

res.send({});
})
},
}