gpt4 book ai didi

javascript - 异步如何真正工作以及如何在 node.js (node-webkit) 中正确使用它

转载 作者:行者123 更新时间:2023-11-30 05:36:42 24 4
gpt4 key购买 nike

关于这个问题,我正在使用 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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com