更新后的代码
下面是App.js 更新后的代码,会在更改后的代码后加上 // 更改后的代码 字样。
var http = require("http");
module.exports = App;
function App(){
// 插件有序列表
var middleList = this._middleList = [];
var self = this;
this._route_post_handles = {} // 更改后的代码
this._route_get_handles = {} // 更改后的代码
// request事件响应函数
function handle(req,res){
// 循环执行插件
var middleIndex = 0; // 插件索引
execMiddle();
// 执行这个函数时,会自动执行下一个middle插件。
// 至于这个函数的执行,是由插件所控制。
function next(){
middleIndex += 1;
execMiddle();
}
// 执行插件函数
function execMiddle(){
var middle = middleList[middleIndex];
if(middle){
middle(req,res,next);
}else{
var handle; // 更改后的代码
// 判断是GET还是POST方法
switch(req.method){
case "GET":
handle = self._route_get_handles[req.url] // 更改后的代码
break;
case "POST":
handle = self._route_post_handles[req.url] // 更改后的代码
break;
}
if(handle){
handle(req,res);
}
}
}
}
this._server = http.createServer(handle);
}
// 加入功能栈
App.prototype.use = function(middle){
this._middleList.push(middle);
}
App.prototype.get = function(route,handle){ // 更改后的代码
this._route_get_handles[route] = handle;
}
App.prototype.post = function(route,handle){ // 更改后的代码
this._route_post_handles[route] = handle;
}
// 监听端口
App.prototype.listen = function(){
this._server.listen.apply(this._server,arguments);
}下一节,要做个路由的例子。