说明
- 上一篇: [MVC实现之三]
- 上一篇实现了,Router层、Controller层、Service层的基本原则,并且成功的通过Mar类来传递这些层级之间需要的参数.
- 这一篇主要是通过业务层面来具体实现:
- Router层:监听页面的路由,并调用Controller层的路由处理函数
- Controller层:给Router层提供服务,调用Service层提供的数据处理.
开始
打开浏览器访问: localhost:3000
- 此时并没有,路由处理函数.
- 栗子: 返回一条数据
Router层
- 思路:
1.在该层调用koa-router
2.建立路由和路由处理函数的联系
3.挂载路由
4.定义规则:将this.koa = new koa(conf)
改为this.$app = new koa(conf)
,使参数更具有语义(是一个koa的实例).
const koa = require('koa');
const koaRouter = require('koa-router');
class Mar {
constructor(conf) {
this.$app = new koa(conf);
this.$router = new koaRouter();
this.service = new Service(this);
this.controller = new Controller(this)