javascript – NodeJS模块化

所以我被告知,在nodeJS中传递请求和/或响应变量是“不好的做法”.但这意味着你的大部分代码都必须在server.js文件中,使其变得乱七八糟.

您如何模块化您的nodejs服务器,适当地传递req / res,并能够将您的代码组织成单独的文件

例如,我想将我的套接字路由,.get和.post分割成不同的文件,但仍然可以使用回调参数:

app.io.route("disconnect",function(req,res) { <--- these params
    db.query("UPDATE player_data SET online=0 WHERE id="+MysqL.escape(req.session.user));
    req.io.broadcast("event",{msg:req.session.username+" has logged out!"});
    app.io.broadcast("reloadXY");
});

到目前为止,它们都在一个文件中,我不喜欢这样.

解决方法

我认为这个人所谓的“传递”是这样的(简单明了):
app.get('/kittens',res) {
  db.doAthing(req);
  updateSomethingElse(res);
  upVoteThisAnswer(res);
});

也就是说,传递超出第一个函数的两个变量.这是坏的,因为越来越难找出呼叫实际结束的地方. updateSomethingElse中的一个小小的res.end(500)可能会导致整个卡片的屋子塌下来.

完全可以(事实上,在express中认为标准)在其他地方声明回调(通常是你的项目的/ routes目录).

// app.js

var user = require('./routes/user'),kittens = require('./routes/kittens');

// express stuff...

app.get('/settings',user.getSettings);
app.get('/fur',kittens.shed);

然后,在routes / user.js中

exports.getSettings = function(req,res) {
  // Note how we're passing around properties of req/res,not the objects themselves.
  db.getUserSettings(req.user.id).then(function(settings) {
    res.render('settings',settings);
  });
};

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...