如何通过带有nodejs的套接字从服务器到客户端进行通信?

时间:2013-03-22 09:11:56

标签: javascript node.js socket.io appjs

目前我正在创建一个Javascript应用程序。我正在使用AppJS

我在理解客户端和服务器之间的连接时遇到了一些问题。

菜单栏 - >套接字问题

问题是菜单栏和套接字组合。

套接字连接

io.sockets.on('connection', onSocketConnection)

function onSocketConnection(socket) {
    socket.emit('onMessage', {
        date: new Date(),
        message: 'Welcome!'
    })
}

菜单栏

var menubar = app.createMenu([{
    label:'File',
    submenu:[{
        label:'New',
        action: function() {
            // Simply window.reload() or windows.frame.reload()?    
            // Reload window
        }
    },{
        label:'Change something in view...',
        action: function() {
            // How to speak to client from here?
            // I cannot use socket.emit()
        }
    }, {
        label:'Exit',
        action: function() {
            window.close()
        }
    }]
}])

但是如何在用户点击菜单栏项目时告诉客户端?

异步长功能 - >插座

使用套接字的另一个问题是异步长加载函数。

套接字连接

io.sockets.on('connection', onSocketConnection)

function onSocketConnection(socket) {
    var test = veryLongLoading()
    console.log(test) // undefined -.-'
    socket.emit('test', {
        test: test

    })
}

所以我认为我需要使用这样的回调:

io.sockets.on('connection', onSocketConnection)

function onSocketConnection(socket) {
    veryLongLoading(returnValue)
}

function veryLongLoadingFunction(next) {
    // Blablabla
    next('test')
}

function returnValue(value) {
    // Again socket is not available -.-'
    socket.emit('test', {
        test: test
    })
}

任何人都面临同样的问题,或者任何能指出我正确方向的人。

也许我只是误解了流程(我在PHP中正常编程)

1 个答案:

答案 0 :(得分:0)

问题1

对于第一部分,您需要侦听来自服务器的事件:

socket.on('message-from-server', function(data) {
  // You need to trigger the sub-menu change here.
  // Which means you need a handle for the sub-menu object.
  subMenu.action(data)
});

问题2

长时间运行异步函数的模式如下所示:

var veryLongLoading = function(next) {
   // pass your value to next
   // like this
   next(someValue);
};

然后使用它,你会这样做:

veryLongLoading(function(someValue) {
   socket.emit(someValue);
});

希望有所帮助!