JQuery新手:我需要一个setTimeout来实现长时间运行的功能

时间:2015-12-24 21:25:22

标签: javascript jquery

我正在开发一个可以选择收集许多数据点的网络应用。此操作可能需要10-15分钟。

我写了一些JQuery,在回调链中加载div。 但是,似乎如果函数需要很长时间才能完成,那么 无论如何都要回电。

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

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

干杯

编辑:修正了语法问题 假设我的语法是正确的,上述函数的长运行时间是否仍然可能会导致问题?

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

<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>

1 个答案:

答案 0 :(得分:2)

如果.load成功完成,您可以清除超时功能。那是你要的吗?

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

或者,您可以使用status回调

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

如果要以ms为单位指定.ajax,则应该使用timeout语法。我不确定您是否可以直接使用.load执行此操作。看看这个answer