- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个页面,我在其中触发 ajax 请求并在用户按下按钮后的前 6 秒内显示加载标志:
<button onclick="runLoader();"></button>
<script>
var startTime=(new Date).getTime();
function runLoader(){
runAjax();
var i=0;
var timer = setInterval(function(e){
i++;
//code for loading sign
if(i==3)
clearInterval(timer);
} ,2000);
}
function runAjax(){
$.ajax({
//
}).done(function(){
var timer2 = setInterval(function(){
var d = new Date();
var t = d.getTime();
if(t-startTime>=6000){
clearInterval(timer2);
// do X
}
},500);
}
}
</script>
我只想在 runLoader()
运行 6 秒并且 runAjax()
产生响应后才执行操作 X ,而且很快。
比如,如果 runAjax() 在 2 秒内响应,我仍然想继续显示加载标志 6 秒,然后执行 X。如果加载标志已显示 6 秒,我想等待 runAjax() 返回所需的时间。
但是使用 Date()
方法会给出不准确的结果。例如:即使只过去了 2 秒,它也显示已经过去 7.765 秒。我在某处读到我应该使用 console.log(time)
以获得更高的准确性,但它在 <=IE9 中不起作用。
有没有更好的方法来解决这个问题?
注意:我正在使用 setInterval()
而不是 setTimeout()
因为加载涉及循环遍历 3 个元素的数组,“Fetching”、“Processing”和“Loading”各显示 2 秒 :)
最佳答案
function start(){
$.when(runLoader(), runAjax()).done(function() {
//both are now finished
});
}
function runLoader() {
//show loader here
var def = $.Deferred();
setTimeout(function() {
//hide loader here
def.resolve(true);
}, 6000);
return def.promise();
}
function runAjax() {
var def = $.Deferred();
$.ajax({...}).done(function(result) {
//handle response here
def.resolve(true);
});
return def.promise();
}
关于Javascript : Do Action after elapsed time,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19297131/
我对这 4 个完全困惑。ElapsedMilliseconds (long)、ElapsedTicks (long)、Elapsed.TotalMilliseconds (double) 和 Elap
我已经包含了 System.Timers 包,但是当我输入时: Timer.Elapsed; //its not working, the property elapsed is just not t
我有一个要使用的 System.Timers.Timer 对象,但我不希望绑定(bind)到 Timer 的处理干扰普通到高优先级线程。换句话说,我想说我想每 5 秒处理一次 X,只要没有其他东西在运
在我的应用程序中,有时我需要手动调用我的计时器。 我试过以下方法: int originalInterval = t.Interval; t.Interval = 0; t.Interval = or
我有一个页面,我在其中触发 ajax 请求并在用户按下按钮后的前 6 秒内显示加载标志: var startTime=(new Date).getTime(); function
我想为每个对象分配不同的计时器。 每个对象都包含 Timer 作为类成员。 这就是我尝试过的: private void EntityTimeElapsed(object sender, MyEnti
我正在使用 Windows 窗体。我正在使用 System.Timers.Timer 。虽然我用 timer.Stop() 停止了计时器,但它仍然会多一点。我放了一些 bool 变量来防止这种情况但没
我正在使用 LabVieW 计算电路的电容。我试图得到它两端的电压达到2.5V后的时间。我提供5V电源。我使用了逻辑运算符并将其连接到耗时组件的重置。但随着时间重置,我得到了零。我想知道实际耗时。 电
我必须在大学做一个小作业: 我有一台运行“n”个独立服务的服务器。过去所有这些服务都是同时启动的。每个服务“i”都会在一定时间“s[i]”(以秒为单位)后将“b[i]”行写入服务器上的日志文件。输入由
我有这个投票类 class Poll { public string question { get; set; } public Timer pollTimer { get; set;
以下类来自 .Net Windows 服务。 DoSomeDatabaseStuff 方法在第一次启动时需要 10 分钟,但当时间过去后,不会再次调用此方法。 public class Test {
Timers.Timer 来创建秒表。我使用 Timer.Elapsed 来处理在特定时间后显示时间的事件。我给定时器间隔 1 并启用为真。我还将 AutoReset 设置为 true。但问题是事件只
我有一个计时器,我想知道它是否有效以测试它是否是计时器第一次引发经过的事件(我想在第一次引发经过的事件后更改 Interval 属性) _timer = new Timer(1000)
我有一个 Backgroundworker,它从数据库中收集大量数据。我想在线程上设置一个超时限制,这样如果它在设定的时间后没有返回结果,进程就会被取消。 我在启动 BackgroundWorker
ElapsedTicks & Elapsed.Ticks 是 Stopwatch 的属性,我觉得应该是一样的。如果它们相同,为什么它们应该给出不同的输出? 代码: Stopwatch spwt = S
我正在使用 Windows 窗体应用程序并拥有一个使用 System.Timers.Timer 定期检查数据库数据的管理器类。 如何将计时器 Elapsed 事件处理程序中发生的异常传递给主应用程序?
我正在使用 System.Timers.Timer 类创建一个带有 Timer.Elapsed 事件的计时器。问题是 Timer.Elapsed 事件仅在间隔时间过去后才第一次触发。 有没有办法在启动
我有一个获取音频的脚本。我想将该频率与歌曲的确切时间联系起来。我可以获取 webkitAudioContext currentTime 属性,但这并不准确,因为它在歌曲开始之前将声音保存在缓冲区中时开
我有下面的代码来获取当前时间戳并计算最后时间戳的耗时(以分钟为单位),我想知道是否可以进一步针对生产进行优化 public static Timestamp getTimestamp() {
我正在尝试获取在响应式(Reactive)编程中从 Redis 读取数据的执行时间,在查找文档时我可以看到 elapsed() 方法将执行相同的操作并实现如下代码。 Flux.fromIterable
我是一名优秀的程序员,十分优秀!