socket.io服务端回调科学的写法是什么样的

服务端在接收到消息后会执行一个耗时的函数foo
该函数通过回调获取运行结果

我目前实现的方法是这样的

buildCallback=(socket)->
    (result)->
        socket.emit('result',result)

io.sockets.on('connection',(socket)->
    socket.on('run',()->
        foo(buildCallback(@))
    )
)

这种场景下有没有更科学的写法

阅读 4.2k
1 个回答

我觉得可能需要一个路由机制来避免on 'connection'代码越堆越多

简单的人肉实现可以是

#server.coffee
events = glob "event/**/*.coffee" .map (file)->
  event = require file
io.sockets.on 'connection', (socket)->
  events.forEach (event)->
    socket.on(event.name, event.handler.bind(socket))

#event/foo.coffee

module.exports = 
  name: 'run'
  handler: ->
    socket = @
    ...

文艺一点的实现可以看看Express.IO

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏