欢迎您访问宜州一中 您可以登录 或注册
 
收藏本站 简繁转换
一方天地育桃李,三尺讲台竞风采             宜州区一中在宜州博物馆举行“人杰地灵读宜州”故事分享会             宜州一中举行2024届中考百日誓师大会             龙腾启新 筑梦未来 ——宜州区第一中学欢庆2024年元旦文艺晚会             走进嘉联丝厂 畅享研学之乐 ——宜州区第一中学开展研学实践活动             2023年河池市宜州区第一中学/宜州区红卫学校家庭经济困难大学新生入学资助项目发放名册(第二批)             展科技志向,圆飞行梦想 ——宜州区一中2025届举行无人机大赛             2023年河池市宜州区第一中学\红卫学校 家庭经济困难大学新生入学资助项目发放名册(第一批)             法制进校园 以法促成长 ——宜州一中举行“三姐护蕾”法治进校园活动             “英”你精彩,“语”你同行 —— 我校2025届举行英文风采大赛            

DoraCMS

您现在的位置是:首页>文档内容页

文档详情

第4天 路由——更新后的代码

doramart 2024-05-13 04:38:10 技术文档232123
下面是App.js 更新后的代码,会在更改后的代码后加上 // 更改后的代码 字样。

更新后的代码

下面是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);
}

下一节,要做个路由的例子。

文章评论

取消回复
登录 参与评论

评论列表(