目前我正在创建一个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中正常编程)
答案 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);
});
希望有所帮助!