最简单的node动态加载路由,即看即用!!


前言

本文主要介绍的是node动态加载路由文件。当做一个工具类来使用就好。

以下是本篇文章正文内容

一、动态加载路由的原理

1、为什么要动态加载路由?
nodejs项目越来越大,手动去添加路由会非常麻烦,并且很容易出错。因此我们使用代码的方式来实现程序启动自动加载路由。在添加路由文件的时候并不用手动添加。
注意⚠️⚠️⚠️:本文介绍的动态加载路由的方式要在路由文件中手动注册路由 如果要全自动的不用手动注册路由的请看:全自动加载路由文件

二、使用步骤

1、在app.js同级目录增加route.js文件

这个文件是我们手动加载路由的核心代码。

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;

2、在app.js中引入:var route = require(’./route’);

app.js中引入,代码如下:

var route = require(./route’);

3、调用方法

在app变量初始化之后,在app.js中使用route.init(app,[可选参数,路由目录,默认为./routes/])。

route.init(app,[可选参数,路由目录,默认为./routes/])参数说明:
第一个参数:传默认app
第二个参数:传路由文件路径

4、验证

关于验证的方式有很多,例如
一、使用工具请求现在的接口是否正确判断route是否加载成功。
二、在路由文件下新建一个路由文件,然后重启项目,看是否加载成功。


总结

本文主要介绍的是node动态加载路由的方法,其实能把它当作一个工具类,使用于任何node项目来动态加载路由。在使用过程中有什么问题大家在评论区指出或者私信告知都🉑️,再次感谢大家阅读本篇博文❤️❤️

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值