setTimeout 不断吐食CPU的问题分析
更新时间:2009年04月01日 00:47:48 作者:
有时候我们在使用setTimeout的时候会导致IE特别占用cpu,有可能会导致死机等情况。
复制代码 代码如下:
<script language="javascript">
function PollConn(){
TimeCounter=window.setTimeout('PollConn();',5000);
function StopPoll(){
window.clearTimeout(TimeCounter)
}
PollConn();
</script>
上面的方法一般是比较通用的方法。不停的每隔5秒钟调用一下自己。在一般的运用中,用户访问含有这样代码的页是没感觉出它有什么问题。但是如果用户在这样的页里需要停留的时间很长,就会用问题。因为setTimeout会不停的“吐食”CPU,慢慢的CPU最终会被这样的代码吃光,造成IE死掉,或停止执行。
解决的办法,在下次调用之前先用clearTimeout清除一下。
复制代码 代码如下:
<script language="javascript">
function PollConn(){
if(TimeCounter) window.clearTimeout(TimeCounter) //清除上次的setTimeout
TimeCounter=window.setTimeout('PollConn();',5000);
function StopPoll(){
window.clearTimeout(TimeCounter)
}
PollConn();
</script>
相关文章
JavaScript中如何让 x == 1 && x == 2 && x == 3 等式成立
这篇文章主要介绍了JavaScript中如何让x==1&&x==2&&x==3等式成立,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下2022-07-07在javascript将NodeList作为Array数组处理的方法
在Web前端编程中,我们通常会通过document.getElementsByTagName的方法取出一组相同标签的dom元素。2010-07-07
最新评论