mirror of
https://github.com/PanJiaChen/vue-element-admin.git
synced 2025-04-06 03:57:53 +08:00
* feat: perfect migrate to @vue/cli-service, upgrade vue babel version 1. update to @vue/cli-service@3.0.5, @babel/core@7.0.0 2. use vue-cli service replace config file in build/ and config/ 3. upgrade vue and babel configuration 4. solve the svg-sprite config problem #980 refs: #932 #1087 #980 #1056 * fix: fix breadcrumb dependency * fix: fix index template and static assets load with vue-cli 3 * fix: fix import driver.js in guide page * refactor(mock): mak mock api compatible with both web-view and webpack server 1. 把 Mockjs 功能移到 server 端中间件,同时也兼容前端直接劫持 XHR 2. dev 环境下默认作为 express 中间件通过 webpack server 提供 mock api 3. prod 构建时,默认在前端用 Mockjs 劫持 XHR benefits: - dev 开发调试时能直接看到 XHR 请求,方便调试网络,能和后端对接联调 - 避开在开发时因为 Mockjs 引起的网络 bug - prod 构建时劫持 XHR,保证本项目的 Github Pages preview 能正常显示 (逻辑和 error-log 一样) - 前后台使用的 mock 是同一份代码,不会增加维护负担 ref: [#562](https://github.com/PanJiaChen/vue-element-admin/issues/562#issuecomment-378116233) * update requires the lowest version of node * add favicon * fix(TreeTable): fix `Array.prototype.concat` on custom-tree-table page
75 lines
1.9 KiB
JavaScript
75 lines
1.9 KiB
JavaScript
import Mock from 'mockjs'
|
|
|
|
const List = []
|
|
const count = 100
|
|
|
|
const baseContent = '<p>我是测试数据我是测试数据</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: '我是测试数据',
|
|
content: baseContent,
|
|
forecast: '@float(0, 100, 2, 2)',
|
|
importance: '@integer(1, 3)',
|
|
'type|1': ['CN', 'US', 'JP', 'EU'],
|
|
'status|1': ['published', 'draft', 'deleted'],
|
|
display_time: '@datetime',
|
|
comment_disabled: true,
|
|
pageviews: '@integer(300, 5000)',
|
|
image_uri,
|
|
platforms: ['a-platform']
|
|
}))
|
|
}
|
|
|
|
export default {
|
|
'/article/list': 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 {
|
|
total: mockList.length,
|
|
items: pageList
|
|
}
|
|
},
|
|
'/article/detail': config => {
|
|
const { id } = config.query
|
|
for (const article of List) {
|
|
if (article.id === +id) {
|
|
return article
|
|
}
|
|
}
|
|
},
|
|
'/article/pv': {
|
|
pvData: [
|
|
{ key: 'PC', pv: 1024 },
|
|
{ key: 'mobile', pv: 1024 },
|
|
{ key: 'ios', pv: 1024 },
|
|
{ key: 'android', pv: 1024 }
|
|
]
|
|
},
|
|
'/article/create': {
|
|
data: 'success'
|
|
},
|
|
'/article/update': {
|
|
data: 'success'
|
|
}
|
|
}
|