日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

nodejs动态加载路由

發布時間:2024/1/8 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 nodejs动态加载路由 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

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/]),即可動態加載路由文件了;

工具源代碼:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
/**

  • 動態遍歷目錄加載路由工具
  • 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;

總結

以上是生活随笔為你收集整理的nodejs动态加载路由的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。