我正在开发一个可以选择收集许多数据点的网络应用。此操作可能需要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>
答案 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