3

目前我正在创建一个 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 编程)

4

1 回答 1

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

The pattern for long running async functions look like this:

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

Then to use it, you would do this:

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

Hope that helps!

于 2013-03-29T03:43:32.677 回答