nodejs动态加载路由
Nodejs動(dòng)態(tài)加載路由,Nodejs遍歷目錄,Nodejs路由工具
工具來源:
Nodejs需要手動(dòng)加載路由文件,如果一個(gè)個(gè)添加,項(xiàng)目逐漸擴(kuò)大,比較麻煩。
尤其在項(xiàng)目route目錄下,增加模塊文件夾的時(shí)候,引入路由更是麻煩。
因此寫了一個(gè)Nodejs動(dòng)態(tài)加載路由,Nodejs遍歷目錄,Nodejs路由工具,取名為route.js。
支持無限級(jí)別目錄結(jié)構(gòu),自動(dòng)遞歸引用。有任何更好的建議,歡迎隨時(shí)留意交流。
使用方法:
1、文件:app.js同級(jí)目錄增加route.js文件,復(fù)制下面貼出源代碼;
2、引入:app.js中引入:var route = require(’./route’);
3、調(diào)用:在app變量初始化之后,在app.js中使用route.init(app,[可選參數(shù),路由目錄,默認(rèn)為./routes/]),即可動(dòng)態(tài)加載路由文件了;
工具源代碼:
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
/**
- 動(dòng)態(tài)遍歷目錄加載路由工具
- author: bling興哥
*/
var fs = require(“fs”);
// 動(dòng)態(tài)路由
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]);
// 是目錄,需要繼續(xù)
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(’.’)));
// 在路由文件中定義了一個(gè)basePath變量,設(shè)置路由路徑前綴
if(route.basePath){
this.app.use(route.basePath,route);
}else{
this.app.use(route);
}
},
// 初始化入口
init : function(app,path){
if(!app){
console.error(“系統(tǒng)主參數(shù)App未設(shè)置”);
return false;
}
this.app = app;
this.path = path?path:this.path;
this.listDir(this.path);
}
};
module.exports = loadRoute;
總結(jié)
以上是生活随笔為你收集整理的nodejs动态加载路由的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 轻松一刻
- 下一篇: 全球开发者各出奇招:我们想这样适配iPh