服务端在接收到消息后会执行一个耗时的函数foo 该函数通过回调获取运行结果
我目前实现的方法是这样的
buildCallback=(socket)-> (result)-> socket.emit('result',result) io.sockets.on('connection',(socket)-> socket.on('run',()-> foo(buildCallback(@)) ) )
这种场景下有没有更科学的写法
学习是最好的投资!
我觉得可能需要一个路由机制来避免on 'connection'代码越堆越多
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
我觉得可能需要一个路由机制来避免
on 'connection'
代码越堆越多简单的人肉实现可以是
文艺一点的实现可以看看Express.IO