JQuery新手:长时间运行的函数需要setTimeout吗

JQuery Newbie: Do I Need a setTimeout for long running function

本文关键字:setTimeout 函数 新手 长时间 运行 JQuery      更新时间:2023-09-26

我正在开发一个web应用程序,该应用程序可以选择收集许多数据点。此操作可能需要长达10-15分钟的时间。

我写了一些JQuery,在回调链中加载div。但是,如果函数需要很长时间才能完成不管怎样,回调都会加载。

我怀疑另一个错误可能是罪魁祸首,并添加了更多的错误日志记录和检查。

我仍然想知道这种行为是否可以归因于超时问题?

干杯

EDIT:修复了语法问题假设我的语法是正确的,那么上面提到的函数运行时间过长是否仍有可能导致问题?

或者这更可能是一个错误或未处理的错误?

<script type="text/javascript">
    setTimeout("alert('timeout');", 800000)
$(function() {
    $("#chart").load("/run_analysis/", function() {
        $("#stem").slideDown("fast");
    });
});
</script>
<body>
<div id="chart">Collecting Data</div>
<div id=stem style="display: none">
<a href="/stem/">Single Word Analysis</a>
</div>
</body>

如果.load成功完成,则可以清除超时功能。这就是你想要的吗?

var timer = setTimeout(function(){ alert("timeout"); }, 800000);
$("#chart").load("/run_analysis/", function() {
    $("#stem").slideDown("fast");
    clearTimeout(timer);
});

或者,您可以使用.load回调的status参数

$("#chart").load("/run_analysis/", function(response,status,xhr) {
    if (status == "timeout")
        alert("Timed out...");
    if (status == "success")        
        $("#stem").slideDown("fast");
});

如果要以毫秒为单位指定timeout,则可能应该使用.ajax语法。我不确定是否可以直接使用.load来执行此操作。查看此答案