Express中server和路由分离

express是node中很强大的web开发框架,通过使用它,可以快速的的开发一个web应用
先看一下一个express应用的目录结构
这里写图片描述

bin:存放可执行文件
node_modules:存放package.json中配置的模块
public:存放image,css,js文件
routes:存放路由文件
views:存放模板文件
app.js:启动文件,文件入口
package.json:存放模块依赖,当使用命令npm install的时候,会自动检查package下配置的模块,并把模块安装到node_modules中

express会默认把负责路由功能的代码放到app.js中,随着项目越来越复杂,app.js文件就显得越臃肿,难以维护,这就需要把路由从app.js中分离出来
先看一下app.js中的代码

var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');

var routes = require('./routes/index');

var app = express();

app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');

app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: false}));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

app.use('/', routes);

app.use(function (req, res, next) {
    var err = new Error('Not Found');
    err.status = 404;
    next(err);
});

if (app.get('env') === 'development') {
    app.use(function (err, req, res, next) {
        res.status(err.status || 500);
        res.render('error', {
            message: err.message,
            error: err
        });
    });
}

app.use(function (err, req, res, next) {
    res.status(err.status || 500);
    res.render('error', {
        message: err.message,
        error: {}
    });
});


module.exports = app;

index.js中的代码

var express = require('express');
var router = express.Router();

 //GET home page. 
 router.get('/', function (req, res, next) {
 res.render('index', {title: 'Express'});
 });

下面进行路由的分离,把路由控制器的函数放到index.js中

第一步,先对app.js进行修改

var routes = require('./routes/index');

改为

var routes = require('./routes');

把app通过传参的方式传到index.js中

routes(app);

修改后的app.js

var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');

var routes = require('./routes');

var app = express();

app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');

app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: false}));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

routes(app);

app.use(function (req, res, next) {
    var err = new Error('Not Found');
    err.status = 404;
    next(err);
});

if (app.get('env') === 'development') {
    app.use(function (err, req, res, next) {
        res.status(err.status || 500);
        res.render('error', {
            message: err.message,
            error: err
        });
    });
}

app.use(function (err, req, res, next) {
    res.status(err.status || 500);
    res.render('error', {
        message: err.message,
        error: {}
    });
});

module.exports = app;

第二步,对index.js进行改造
改造后的index.js

var express = require('express');
var router = express.Router();

module.exports = function (app) {
    app.get("/", function (req, res) {
        res.render('index', {title: '首页'});
    });

    app.get('/about', function (req, res) {
        res.render('about', {title: '关于'});
    });
}

在views中把index.ejs复制一份,改为about.ejs,以便测试

npm start 启动

首页的效果
这里写图片描述

about的效果
这里写图片描述

运行成功,改造完成

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,下面我将为您介绍如何使用 Node.js 和 Express 框架搭建一个后台服务器,并实现路由模块化。 1. 安装 Node.js 首先需要在您的电脑上安装 Node.js。您可以在官网(https://nodejs.org/)下载并安装最新版的 Node.js。 2. 初始化项目 打开命令行工具,进入您想要创建项目的目录,执行以下命令: ``` npm init -y ``` 这个命令将会初始化一个新的 Node.js 项目,并在 package.json 文件添加一些基本配置。 3. 安装 Express 框架 执行以下命令来安装 Express 框架: ``` npm install express ``` 4. 编写服务器代码 在项目根目录下,创建一个名为 `app.js` 的文件,并编写以下代码: ```javascript const express = require('express'); const app = express(); // 路由模块化 const userRouter = require('./routes/user'); app.use('/user', userRouter); app.listen(3000, () => { console.log('Server is running on port 3000!'); }); ``` 以上代码使用 `require` 引入了 Express 模块,并创建了一个 Express 应用程序实例。然后,我们通过 `app.use` 方法来加载路由模块。 5. 创建路由模块 在项目根目录下,创建一个名为 `routes` 的文件夹,在 `routes` 文件夹下创建一个名为 `user.js` 的文件,并编写以下代码: ```javascript const express = require('express'); const router = express.Router(); router.get('/', (req, res) => { res.send('Hello World!'); }); module.exports = router; ``` 以上代码创建了一个 Express 路由实例,并使用 `router.get` 方法来定义一个 GET 请求的路由。在路由处理函数,我们使用 `res.send` 方法来发送一个字符串作为响应。 6. 运行服务器 在命令行工具执行以下命令来启动服务器: ``` node app.js ``` 此时您可以在浏览器访问 `http://localhost:3000/user` 来查看响应结果。 至此,您已经成功搭建了一个后台服务器,并实现了路由模块化。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值