zoukankan      html  css  js  c++  java
  • Nodejs动态加载路由,Nodejs遍历目录,Nodejs路由工具

    工具来源:
     
    Nodejs需要手动加载路由文件,如果一个个添加,项目逐渐扩大,比较麻烦。
    尤其在项目route目录下,增加模块文件夹的时候,引入路由更是麻烦。
    因此写了一个Nodejs动态加载路由,Nodejs遍历目录,Nodejs路由工具,取名为route.js。
     
    支持无限级别目录结构,自动递归引用。有任何更好的建议,欢迎随时留意交流。
     
    使用方法:
     
    1、文件:app.js同级目录增加route.js文件,复制下面贴出源代码;
    2、引入:app.js中引入:var route = require('./route');
    3、调用:在app变量初始化之后,在app.js中使用route.init(app,[可选参数,路由目录,默认为./routes/]),即可动态加载路由文件了;
     
    工具源代码:
     
    /**
     * 动态遍历目录加载路由工具
     * author: bling兴哥
     */
    var fs = require("fs");
    // 动态路由
    var loadRoute = {
        path : './routes/',
        app : null,
        // 遍历目录
        listDir : function(dir){
            var fileList = fs.readdirSync(dir,'utf-8');
            for(var i=0;i<fileList.length;i++) {
                var stat = fs.lstatSync(dir + fileList[i]);
                // 是目录,需要继续
                if (stat.isDirectory()) {
                    this.listDir(dir + fileList[i]  + '/');
                } else {
                    this.loadRoute(dir + fileList[i]);
                }
            }
        },
        // 加载路由
        loadRoute : function(routeFile){
            console.log(routeFile);
            var route = require(routeFile.substring(0,routeFile.lastIndexOf('.')));
            // 在路由文件中定义了一个basePath变量,设置路由路径前缀
            if(route.basePath){
                this.app.use(route.basePath,route);
            }else{
                this.app.use(route);
            }
        },
        // 初始化入口
        init : function(app,path){
            if(!app){
                console.error("系统主参数App未设置");
                return false;
            }
            this.app = app;
            this.path = path?path:this.path;
            this.listDir(this.path);
        }
    };
    
    module.exports = loadRoute;
    
     
  • 相关阅读:
    SAX解析XML笔记
    使用 Angular 2 来创建FlexGrid控件
    算法-快速排序(优雅版)
    使用泛型简化动态代理
    Java泛型概述
    POI-PPT官方文档
    Java 利用POI操作PPT
    Java8学习笔记(九)--日期/时间(Date Time)API指南
    Java8学习笔记(八)--方法引入的补充
    Android WebView加载本地html并实现Java与JS交互
  • 原文地址:https://www.cnblogs.com/bling/p/5541680.html
Copyright © 2011-2022 走看看