关于这个问题,我正在使用 Node-Webkit (node.js) 和 Async , 正在加载 Windows 应用程序。
这个问题的原因是明确回答:
What really means asynchronous execution in Javascript and Node.Js.
我的个人代码问题在问题的末尾。 “案件”。
我将直接用示意图来解释我遇到的所有问题。 (我会在您帮助我理解时更新信息)
概念(理论)
想象一个主屏幕(JS、Html、css、……Node.js 框架)和一个后台程序(每 10 分钟执行一次 JS、JS 内部检查、后台数据库优化……)。
无论您在 Primary Screen 中做什么,都不会影响后台执行(某些重要情况除外),如果需要,Background 甚至可以更改 Screen(屏幕计时器、有关在线网络状态的信息……)
那么行为就像:
Thread 1: Your actions inside the App framework. Thread 2: Background App routines
他们完成后的任何 Action 都会将他的输出显示到屏幕上,尽管其余的 Action 是异步并行的
解释(对我而言)
我认为这是“异步”可以毫无问题地处理的事情,作为并行执行。
async.parallel([
function(){ ... },
function(){ ... }
], callback); //optional callback
因此线程 1 和线程 2 可以正确地协同工作,同时它们不会影响相同的代码或指令。 当任何线程向它请求某些内容时,内容将发生变化。
实现(现实) 代码在执行过程中不是完全异步的,有同步部分和共同的 Action ,当他们需要时调用异步代码。
Sync: Startup with containers -> Async: load multiple content and do general stuff -> Sync: Do an action in the screen -> ...
案例
所以这是我的不能正常工作的代码:
win.on('loaded', function() {
$( "#ContentProgram" ).load( "view/launcherWorkSpace.html", function() {
$("#bgLauncher").hide();
win.show();
async.parallel([
function() //**Background Process: Access to DB and return HTML content**
{
var datacontent = new data.GetActiveData();
var exeSQL = new data.conn(datacontent);
if(exeSQL.Res)
{
var r = exeSQL.Content;
if(r.Found)
{
logSalon = new data.activeSData(r)
$('#RelativeInfo').empty();
$("#RelativeInfo").html("<h4 class='text-success'>Data found: <b>" + logData.getName + "</b></h4>");
}
}
},
function() //**Foreground Process: See an effect on screen during load.**
{
$("#bgLauncher").fadeIn(400);
$("#centralAccess").delay(500).animate({bottom:0},200);
}
]);
});
});
如您所见,我没有使用“Callback()”,因为我不需要(它也是这样做的)。
即使后台进程未完成,我也想执行前台进程,但代码的结果是在两个请求完成时同时完成...
如果我手动断开数据库,第一个函数需要 3 秒,直到给出异常(我不会处理)。在那之前,两个过程都不会输出(在屏幕上显示)任何东西。 (无论后台进程发生什么情况,都应启动前台进程)。
感谢并抱歉对看似微不足道的事情进行了如此多的解释。
已编辑
这开始很烦人......我试过不使用异步,只是一个带有回调的 javascript,如下所示:
launchEffect(function () {
var datacontent = new data.GetActiveData();
var exeSQL = new data.conn(datacontent);
if(exeSQL.Res)
{
var r = exeSQL.Content;
if(r.Found)
{
logData = new data.activeData(r)
$('#RelativeInfo').empty();
$("#RelativeInfo").html("<h4 class='text-success'>Salón: <b>" + log.getName + "</b></h4>");
}
}
});
});
});
function launchEffect(callback)
{
$("#bgLauncher").fadeIn(400);
$("#centralAccess").delay(500).animate({bottom:0},200);
callback();
}
即使这样...Jquery 在回调答案之前不会工作...
最佳答案
node-webkit
让你运行像 node.js 代码一样编写的代码,但最终只是一个在 WebKit 的 Javascript 运行时运行的垫片,并且只有一个线程,这意味着大多数“异步”代码仍然会阻止任何其他代码的执行。
如果您自己运行 node.js,您会看到不同的行为,因为它可以在幕后执行真正的异步线程。如果您想要更多线程,则需要在您的主机应用中提供它们。
关于javascript - 异步如何真正工作以及如何在 node.js (node-webkit) 中正确使用它,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23279203/