這里就不廢話什么是node,node做什么之類的鹉动。目標(biāo)就是創(chuàng)建基于koa2的一個(gè)node應(yīng)用。
環(huán)境:node v8.11.X mysql 5.7
koa2基本使用:
//koa2 下載
npm init //初始化
npm install koa2 koa-router koa-bodyparser -S //npm包
npm install nodemon -S
//app.js
const Koa = require('koa');
const app = new Koa();
app.use(async ctx => {
ctx.body = "hello koa2!";
});
app.listen(9091);
//瀏覽器訪問(wèn)localhost:9091 輸出hello koa2!
這就是一個(gè)簡(jiǎn)單的koa2應(yīng)用,但是在開(kāi)發(fā)中這樣不能以mvc的的方式有效的管理api,會(huì)對(duì)后期的文件交叉嚴(yán)重吱雏,造成管理困難拒贱。
所以看我們基于koa2的改造
//app.js
const Koa = require('koa');
const app = new Koa();
/**引入控制器*/
const controllers = require('./src/loadderController')();
Koa.prototype['controller'] = {};
controllers.forEach((ctl) => {
Koa.prototype.controller[ctl.name] = ctl.obj;
});
/**引入路由*/
const router = require('./src/loaderRouter');
app.use(router(app));
app.listen(port,()=>{
console.log('server is start......');
})
//src/loaderController.js
const fs = require('fs');
module.exports = ()=>{
const files = fs.readdirSync(__dirname, '../controller');
files.filter((file)=>{
return file.endsWith('.js');
});
files.map((file) => {
let controller = require(__dirname+'/../controller/'+file);
let obj = new controller();
return {name:file.splice('.')[0], obj};
});
}
//src/loaderRouter.js
const koaRouter = require('koa-router');
const router = new koaRouter();
module.exports = (app)=>{
const routes = require(__dirname+'/../router.js')(app);
Object.keys(routes).map((key)=>{
const [method, path] = key.split(" ");
router[method](path, routes[key]);
});
return router.routes();
}
//router.js
module.exports = (app) => {
return {
'get /':app.controller.index.getUser
}
}
//controller/index.js
module.exports = class index{
async getUser(ctx, next){
ctx.body = "getUser";
}
}
執(zhí)行app.js 訪問(wèn)localhost
以上就是基于koa,koa-router創(chuàng)建的api,將路由和業(yè)務(wù)處理控制器分離,路由集中對(duì)應(yīng)業(yè)務(wù)控制器方法崔梗,控制處理業(yè)務(wù)夜只。
缺點(diǎn)在于對(duì)路由中心化處理,這個(gè)后邊將會(huì)有解決方案炒俱,暫時(shí)就這樣處理盐肃。