簡體   English   中英

ExpressJS + Socket.IO路由

[英]ExpressJS + Socket.IO Routing

重復的問題,但我發現沒有完美的答案作為解決方案。 請幫我解決這個問題。

我的App.js

   var routes = require('./routes/index');
   var users = require('./routes/users');
   var media = require('./routes/media');
   var widget = require('./routes/widget');
   var display = require('./routes/displays');
   var device = require('./routes/deviceinfo');

   app.use('/', routes);
   app.use('/display', display);


   var server = http.createServer(app);
   var io = require('socket.io')(server);
   io.set('transports', ['polling', 'websocket']);

顯示路線:“routes / display.js”

我有代碼來插入顯示,創建顯示后,事件應該發送到設備列表。

Emit應該需要寫成保存成功的回調方法。

      var express = require('express');
      var router = express.Router(); 
      router.post('/save', action_save_displays);
      function action_save_displays(req, res){
        display.save(req,body , function(err , display){
               if(!err){
                res.json(display);
                 //io.sockets.emit("displaycreated", display);
              }
        })
      }
       module.exports = routes;

如何在routes / display.js文件中傳遞io.sockets.emit。 真的很感謝你的指導。 如何將socket對象發送到路由以啟用emit事件。

你可以稍微交換一下需求,然后將socket.io傳遞給display.js文件

var routes  = require('./routes/index');
var users   = require('./routes/users');
var media   = require('./routes/media');
var widget  = require('./routes/widget');

var server  = http.createServer(app);
var io      = require('socket.io')(server);
var display = require('./routes/displays')(io); // here

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

app.use('/', routes);
app.use('/display', display);

io.set('transports', ['polling', 'websocket']);

並在display.js文件中獲取它

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

 module.exports = function(io) {

     router.post('/save', function(req, res) {
         display.save(req.body , function(err, display){
             if(!err){
                 res.json(display);
                 io.sockets.emit("displaycreated", display);
              }
         });
     });

    return router;
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM