Skip to content

Commit 3af2b77

Browse files
author
caihuaguang@aixuedai.com
committed
Vue2 + Koa2 简易后台管理系统
1 parent 3735951 commit 3af2b77

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

65 files changed

+3593
-0
lines changed

vue-demo/vue2.x-koa2.x/.babelrc

Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
{
2+
"presets": ["es2015", "stage-0"],
3+
"plugins": ["transform-runtime"],
4+
"comments": false,
5+
"env": {
6+
"test": {
7+
"plugins": [ "istanbul" ]
8+
}
9+
}
10+
}

vue-demo/vue2.x-koa2.x/.editorconfig

Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
root = true
2+
3+
[*]
4+
charset = utf-8
5+
indent_style = space
6+
indent_size = 2
7+
end_of_line = lf
8+
insert_final_newline = true
9+
trim_trailing_whitespace = true

vue-demo/vue2.x-koa2.x/.gitignore

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,4 @@
1+
.DS_Store
2+
node_modules/
3+
dist/
4+
npm-debug.log

vue-demo/vue2.x-koa2.x/README.md

Lines changed: 18 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,18 @@
1+
# vue2.x-koa2.x
2+
3+
> Vue.js 与 Koa.js 的练习项目
4+
5+
## 步骤
6+
7+
``` bash
8+
# 安装依赖
9+
npm install
10+
11+
# 启动本地服务 localhost:8080
12+
npm run dev
13+
14+
# 用于生产环境的构建
15+
npm run build
16+
```
17+
18+
相关参考 [vuejs-templates](http://vuejs-templates.github.io/webpack/) [vue-loader](http://vuejs.github.io/vue-loader).

vue-demo/vue2.x-koa2.x/app.js

Lines changed: 45 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,45 @@
1+
const path = require('path'),
2+
koa = new (require('koa'))(),
3+
koaRouter = require('koa-router')(),
4+
bodyparser = require('koa-bodyparser'), // 解析 body 数据,存放于 ctx.request.body
5+
json = require('koa-json'), // 格式化服务端返回的 JSON 数据
6+
logger = require('koa-logger'), // 日志中间件
7+
koaStatic = require('koa-static'),
8+
historyApiFallback = require('koa-history-api-fallback'),
9+
image = require('./server/routes/image.js'),
10+
user = require('./server/routes/user.js'),
11+
goods = require('./server/routes/goods.js');
12+
13+
koa.use(bodyparser());
14+
koa.use(json());
15+
koa.use(logger());
16+
koa.use(historyApiFallback());
17+
18+
koa.use(async (ctx, next) => {
19+
let start = new Date();
20+
await next();
21+
let ms = new Date - start;
22+
console.log('%s %s - %s', this.method, this.url, ms);
23+
});
24+
25+
koa.on('error', function(err, ctx) {
26+
console.log('server error: ', err);
27+
});
28+
29+
// 静态文件服务 koa-static 规则位于 koa-router 的系列规则之前
30+
koa.use(koaStatic(path.resolve('dist'))); // 将 webpack 打包好的项目目录作为 Koa 静态文件服务的目录
31+
32+
// 挂载到 koa-router 上,同时会让所有的 user 的请求路径前面加上 '/auth' 。
33+
koaRouter.use('/auth', user.routes());
34+
35+
koaRouter.use(goods.routes());
36+
37+
koaRouter.use(image.routes());
38+
39+
koa.use(koaRouter.routes()); // 将路由规则挂载到Koa上。
40+
41+
koa.listen(9090, () => {
42+
console.log('Koa is listening on port 9090');
43+
});
44+
45+
module.exports = koa;

vue-demo/vue2.x-koa2.x/build/build.js

Lines changed: 36 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,36 @@
1+
// https://github.com/shelljs/shelljs
2+
require('./check-versions')()
3+
require('shelljs/global')
4+
env.NODE_ENV = 'production'
5+
6+
var path = require('path')
7+
var config = require('../config')
8+
var ora = require('ora')
9+
var webpack = require('webpack')
10+
var webpackConfig = require('./webpack.prod.conf')
11+
12+
console.log(
13+
' Tip:\n' +
14+
' Built files are meant to be served over an HTTP server.\n' +
15+
' Opening index.html over file:// won\'t work.\n'
16+
)
17+
18+
var spinner = ora('building for production...')
19+
spinner.start()
20+
21+
var assetsPath = path.join(config.build.assetsRoot, config.build.assetsSubDirectory)
22+
rm('-rf', assetsPath)
23+
mkdir('-p', assetsPath)
24+
cp('-R', 'static/*', assetsPath)
25+
26+
webpack(webpackConfig, function (err, stats) {
27+
spinner.stop()
28+
if (err) throw err
29+
process.stdout.write(stats.toString({
30+
colors: true,
31+
modules: false,
32+
children: false,
33+
chunks: false,
34+
chunkModules: false
35+
}) + '\n')
36+
})
Lines changed: 45 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,45 @@
1+
var semver = require('semver')
2+
var chalk = require('chalk')
3+
var packageConfig = require('../package.json')
4+
var exec = function (cmd) {
5+
return require('child_process')
6+
.execSync(cmd).toString().trim()
7+
}
8+
9+
var versionRequirements = [
10+
{
11+
name: 'node',
12+
currentVersion: semver.clean(process.version),
13+
versionRequirement: packageConfig.engines.node
14+
},
15+
{
16+
name: 'npm',
17+
currentVersion: exec('npm --version'),
18+
versionRequirement: packageConfig.engines.npm
19+
}
20+
]
21+
22+
module.exports = function () {
23+
var warnings = []
24+
for (var i = 0; i < versionRequirements.length; i++) {
25+
var mod = versionRequirements[i]
26+
if (!semver.satisfies(mod.currentVersion, mod.versionRequirement)) {
27+
warnings.push(mod.name + ': ' +
28+
chalk.red(mod.currentVersion) + ' should be ' +
29+
chalk.green(mod.versionRequirement)
30+
)
31+
}
32+
}
33+
34+
if (warnings.length) {
35+
console.log('')
36+
console.log(chalk.yellow('To use this template, you must update following to modules:'))
37+
console.log()
38+
for (var i = 0; i < warnings.length; i++) {
39+
var warning = warnings[i]
40+
console.log(' ' + warning)
41+
}
42+
console.log()
43+
process.exit(1)
44+
}
45+
}
Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
/* eslint-disable */
2+
require('eventsource-polyfill')
3+
var hotClient = require('webpack-hot-middleware/client?noInfo=true&reload=true')
4+
5+
hotClient.subscribe(function (event) {
6+
if (event.action === 'reload') {
7+
window.location.reload()
8+
}
9+
})
Lines changed: 75 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,75 @@
1+
require('./check-versions')()
2+
var config = require('../config')
3+
if (!process.env.NODE_ENV) process.env.NODE_ENV = JSON.parse(config.dev.env.NODE_ENV)
4+
var path = require('path')
5+
var express = require('express')
6+
var webpack = require('webpack')
7+
var opn = require('opn')
8+
var proxyMiddleware = require('http-proxy-middleware')
9+
var webpackConfig = require('./webpack.dev.conf')
10+
11+
// default port where dev server listens for incoming traffic
12+
var port = process.env.PORT || config.dev.port
13+
// Define HTTP proxies to your custom API backend
14+
// https://github.com/chimurai/http-proxy-middleware
15+
var proxyTable = config.dev.proxyTable
16+
17+
var app = express()
18+
var compiler = webpack(webpackConfig)
19+
20+
var devMiddleware = require('webpack-dev-middleware')(compiler, {
21+
publicPath: webpackConfig.output.publicPath,
22+
quiet: true
23+
})
24+
25+
var hotMiddleware = require('webpack-hot-middleware')(compiler, {
26+
log: () => {}
27+
})
28+
// force page reload when html-webpack-plugin template changes
29+
compiler.plugin('compilation', function (compilation) {
30+
compilation.plugin('html-webpack-plugin-after-emit', function (data, cb) {
31+
hotMiddleware.publish({ action: 'reload' })
32+
cb()
33+
})
34+
})
35+
36+
// proxy api requests
37+
Object.keys(proxyTable).forEach(function (context) {
38+
var options = proxyTable[context]
39+
if (typeof options === 'string') {
40+
options = { target: options }
41+
}
42+
app.use(proxyMiddleware(context, options))
43+
})
44+
45+
// handle fallback for HTML5 history API
46+
app.use(require('connect-history-api-fallback')())
47+
48+
// serve webpack bundle output
49+
app.use(devMiddleware)
50+
51+
// enable hot-reload and state-preserving
52+
// compilation error display
53+
app.use(hotMiddleware)
54+
55+
// serve pure static assets
56+
var staticPath = path.posix.join(config.dev.assetsPublicPath, config.dev.assetsSubDirectory)
57+
app.use(staticPath, express.static('./static'))
58+
59+
var uri = 'http://localhost:' + port
60+
61+
devMiddleware.waitUntilValid(function () {
62+
console.log('> Listening at ' + uri + '\n')
63+
})
64+
65+
module.exports = app.listen(port, function (err) {
66+
if (err) {
67+
console.log(err)
68+
return
69+
}
70+
71+
// when env is testing, don't need open it
72+
if (process.env.NODE_ENV !== 'testing') {
73+
opn(uri)
74+
}
75+
})

vue-demo/vue2.x-koa2.x/build/utils.js

Lines changed: 61 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,61 @@
1+
var path = require('path')
2+
var config = require('../config')
3+
var ExtractTextPlugin = require('extract-text-webpack-plugin')
4+
5+
exports.assetsPath = function (_path) {
6+
var assetsSubDirectory = process.env.NODE_ENV === 'production'
7+
? config.build.assetsSubDirectory
8+
: config.dev.assetsSubDirectory
9+
return path.posix.join(assetsSubDirectory, _path)
10+
}
11+
12+
exports.cssLoaders = function (options) {
13+
options = options || {}
14+
// generate loader string to be used with extract text plugin
15+
function generateLoaders (loaders) {
16+
var sourceLoader = loaders.map(function (loader) {
17+
var extraParamChar
18+
if (/\?/.test(loader)) {
19+
loader = loader.replace(/\?/, '-loader?')
20+
extraParamChar = '&'
21+
} else {
22+
loader = loader + '-loader'
23+
extraParamChar = '?'
24+
}
25+
return loader + (options.sourceMap ? extraParamChar + 'sourceMap' : '')
26+
}).join('!')
27+
28+
// Extract CSS when that option is specified
29+
// (which is the case during production build)
30+
if (options.extract) {
31+
return ExtractTextPlugin.extract('vue-style-loader', sourceLoader)
32+
} else {
33+
return ['vue-style-loader', sourceLoader].join('!')
34+
}
35+
}
36+
37+
// http://vuejs.github.io/vue-loader/en/configurations/extract-css.html
38+
return {
39+
css: generateLoaders(['css']),
40+
postcss: generateLoaders(['css']),
41+
less: generateLoaders(['css', 'less']),
42+
sass: generateLoaders(['css', 'sass?indentedSyntax']),
43+
scss: generateLoaders(['css', 'sass']),
44+
stylus: generateLoaders(['css', 'stylus']),
45+
styl: generateLoaders(['css', 'stylus'])
46+
}
47+
}
48+
49+
// Generate loaders for standalone style files (outside of .vue)
50+
exports.styleLoaders = function (options) {
51+
var output = []
52+
var loaders = exports.cssLoaders(options)
53+
for (var extension in loaders) {
54+
var loader = loaders[extension]
55+
output.push({
56+
test: new RegExp('\\.' + extension + '$'),
57+
loader: loader
58+
})
59+
}
60+
return output
61+
}

0 commit comments

Comments
 (0)