为什么 javascript 中的 setInterval 无法正常工作
Why the setInterval in javascript does not work properly
<html>
<head>
<script>
window.onload = function(){
setTimeout(function(){
alert("hi");
}, 4000);
var time = 0;
var para = document.getElementsByTagName("p");
setInterval(function(){
time += 1;
para[0].innerHTML = time;
},1);
}
</script>
</head>
<body>
<p></p>
</body>
</html>
这是我的代码,我想计算显示警报的时间量,我预计它是 4000,但它仅在 9 秒后变为 4xx。为什么会这样?
setInterval
不是很精确。它所做的唯一保证是调用之间的时间大于或等于经过的间隔。在您的情况下,主要问题之一是最小间隔实际上被指定为 4 毫秒。
您可以使用new Date().getTime()
(或Date.now()
,给定支持)获得完全准确的测量 - 这是以毫秒为单位,并且通常是您在执行与测量时间(甚至大多数动画,只是因为它更简单)相关的任何事情时应该使用的测量。
为了扩展我在评论中所说的内容,这应该有效:
setTimeout(function(){
alert("hi");
}, 4000);
var startTime = new Date();
var para = document.getElementsByTagName("p");
setInterval(function(){
var timeElapsed = new Date() - startTime;
para[0].innerHTML = timeElapsed;
},1);
现在,即使您不是每毫秒都进入,而是每 28 毫秒输入一次,您的时间显示也会保持正确。
相关文章:
- Javascript:selenium Web驱动程序isDisplayed()不工作
- jQuery UI自动完成突然停止工作
- AngularJS UI路由器不能像ng路由器那样工作
- HTML5音频加载和播放获胜'我不能在iPad上工作
- JavaScript打印功能使日历停止工作
- Javascript.getHours()工作不正常
- 为什么这在IE中的工作方式与在Firefox中不同
- 视频HTML没有'无法在Internet Explorer 11上工作
- 扩展移相器按钮类不工作
- Firebase迁移-简单的Firebase.set没有'不再工作了——旧的还是新的
- 谷歌地图不是以HTML显示,而是在JS Fiddle上工作
- 正在尝试使用if和else添加类,但无法正常工作
- Jquery FadeIn FadeOut 只工作一次
- Foreach无法在Typescript中工作
- 另一个ajax调用中的Jquery ajax调用在for循环中没有按预期工作
- 为什么不是't窗口.恢复正常工作吗?(javascript/jquery)
- JS可以在Chrome中工作,但不能在Firefox中工作
- ajaxToolkit PopupControlExtender不工作.过时的
- HTML标记在脚本标记中工作
- javascript扫雷器floodfill算法不能正常工作