初学者对Express和socket.io中的模块结构感到困惑

Beginner confused about module structure in Express and socket.io

本文关键字:结构 模块 Express socket io 初学者      更新时间:2023-09-26

我使用默认 Express.js项目结构,主要的js文件涉及我的困惑是:

app.js:定义请求处理程序和使用模块。Exports = app;作为一个模块。

bin/www: require app.js, setup and configure http server.

一切似乎都模块化了。

但是当涉及到Socket时。IO集成,这个结构开始让我困惑:

从套接字。io文档:

var app = require('express')();
var server = require('http').Server(app);
var io = require('socket.io')(server);
server.listen(80);
app.get('/', function (req, res) {
  res.sendfile(__dirname + '/index.html');
});
io.on('connection', function (socket) {
  socket.emit('news', { hello: 'world' });
  socket.on('my other event', function (data) {
    console.log(data);
  });
});

因为插座。io需要服务器变量,所以我弄清楚这段代码应该在www文件,但我也想模块化io事件处理部分成一个模块,但我不知道如何导出io变量到www,因为它需要一个变量服务器从www。

我想知道:这是否意味着我必须在www文件中保留所有socketio事件处理代码?谁能给我一些代码来显示如何模块化这个?

套接字代码的组织不一定是直观的,但你可以把它想象成类似于http方面的东西,以及函数通常提供给路由的方式。

注意,您只是向"io.on"提供了一个函数。你可以这样做。在一个单独的文件中为你的套接字函数创建一个模块…

// File named socket_funcs.js
module.exports.connection = function (socket) {
    socket.emit('news', { hello: 'world' });
    socket.on('my other event', function (data) {
    console.log(data);
});

然后在你的app.js文件中你可以这样做…

var app = require('express')();
var server = require('http').Server(app);
var io = require('socket.io')(server);
var sf = require('./socket_funcs.js');
server.listen(80);
app.get('/', function (req, res) {
    res.sendfile(__dirname + '/index.html');
});
io.on('connection', sf.connection);