vue-vben-admin/mock/demo/table-demo.ts

56 lines
1.5 KiB
TypeScript
Raw Normal View History

2020-10-08 01:35:05 +08:00
import { MockMethod } from 'vite-plugin-mock';
import { Random } from 'mockjs';
2020-10-08 01:35:05 +08:00
import { resultPageSuccess } from '../_util';
function getRandomPics(count = 10): string[] {
const arr: string[] = [];
for (let i = 0; i < count; i++) {
arr.push(Random.image('800x600', Random.color(), Random.color(), Random.title()));
}
return arr;
}
2020-10-08 01:35:05 +08:00
const demoList = (() => {
const result: any[] = [];
for (let index = 0; index < 200; index++) {
2020-10-08 01:35:05 +08:00
result.push({
id: `${index}`,
beginTime: '@datetime',
endTime: '@datetime',
address: '@city()',
name: '@cname()',
name1: '@cname()',
name2: '@cname()',
name3: '@cname()',
name4: '@cname()',
name5: '@cname()',
name6: '@cname()',
name7: '@cname()',
name8: '@cname()',
radio1: `选项${index + 1}`,
radio2: `选项${index + 1}`,
radio3: `选项${index + 1}`,
avatar: Random.image('400x400', Random.color(), Random.color(), Random.first()),
imgArr: getRandomPics(Math.ceil(Math.random() * 3) + 1),
imgs: getRandomPics(Math.ceil(Math.random() * 3) + 1),
date: `@date('yyyy-MM-dd')`,
time: `@time('HH:mm')`,
2020-10-08 01:35:05 +08:00
'no|100000-10000000': 100000,
2020-11-10 22:45:39 +08:00
'status|1': ['normal', 'enable', 'disable'],
2020-10-08 01:35:05 +08:00
});
}
return result;
})();
export default [
{
url: '/basic-api/table/getDemoList',
2021-03-01 00:56:25 +08:00
timeout: 100,
2020-10-08 01:35:05 +08:00
method: 'get',
response: ({ query }) => {
const { page = 1, pageSize = 20 } = query;
return resultPageSuccess(page, pageSize, demoList);
},
},
] as MockMethod[];