123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116 |
- const Mock = require('mockjs')
- const List = []
- const count = 100
- const baseContent = '<p>I am testing data, I am testing data.</p><p><img src="https://wpimg.wallstcn.com/4c69009c-0fd4-4153-b112-6cb53d1cf943"></p>'
- const image_uri = 'https://wpimg.wallstcn.com/e4558086-631c-425c-9430-56ffb46e70b3'
- for (let i = 0; i < count; i++) {
- List.push(Mock.mock({
- id: '@increment',
- timestamp: +Mock.Random.date('T'),
- author: '@first',
- reviewer: '@first',
- title: '@title(5, 10)',
- content_short: 'mock data',
- content: baseContent,
- forecast: '@float(0, 100, 2, 2)',
- importance: '@integer(1, 3)',
- 'type|1': ['CN', 'US', 'JP', 'EU'],
- 'status|1': ['published', 'draft'],
- display_time: '@datetime',
- comment_disabled: true,
- pageviews: '@integer(300, 5000)',
- image_uri,
- platforms: ['a-platform']
- }))
- }
- module.exports = [
- {
- url: '/vue-element-admin/article/list',
- type: 'get',
- response: config => {
- const { importance, type, title, page = 1, limit = 20, sort } = config.query
- let mockList = List.filter(item => {
- if (importance && item.importance !== +importance) return false
- if (type && item.type !== type) return false
- if (title && item.title.indexOf(title) < 0) return false
- return true
- })
- if (sort === '-id') {
- mockList = mockList.reverse()
- }
- const pageList = mockList.filter((item, index) => index < limit * page && index >= limit * (page - 1))
- return {
- code: 20000,
- data: {
- total: mockList.length,
- items: pageList
- }
- }
- }
- },
- {
- url: '/vue-element-admin/article/detail',
- type: 'get',
- response: config => {
- const { id } = config.query
- for (const article of List) {
- if (article.id === +id) {
- return {
- code: 20000,
- data: article
- }
- }
- }
- }
- },
- {
- url: '/vue-element-admin/article/pv',
- type: 'get',
- response: _ => {
- return {
- code: 20000,
- data: {
- pvData: [
- { key: 'PC', pv: 1024 },
- { key: 'mobile', pv: 1024 },
- { key: 'ios', pv: 1024 },
- { key: 'android', pv: 1024 }
- ]
- }
- }
- }
- },
- {
- url: '/vue-element-admin/article/create',
- type: 'post',
- response: _ => {
- return {
- code: 20000,
- data: 'success'
- }
- }
- },
- {
- url: '/vue-element-admin/article/update',
- type: 'post',
- response: _ => {
- return {
- code: 20000,
- data: 'success'
- }
- }
- }
- ]
|