javascript - clearInterval()没有起作用
PHP中文网
PHP中文网 2017-04-11 11:22:34
[JavaScript讨论组]
var i = 0;
var count = null;

$('#user').keypress(function(event){
  var k = event.keyCode;
  if ((k <= 57 && k >= 48) || (k <= 105 && k >= 96)){
    count = setInterval(function(){
      i++;
      console.log("keydown-"+i);
    },500);  
  }else if(k == 13){
    clearInterval(count);
    alert('总共用时-'+i);
  }else{
    return false;
  }
})
    

关掉alert后,控制台的时间一直在不停的跑,为什么clearInterval没有起作用

id="user"是个输入框

PHP中文网
PHP中文网

认证0级讲师

全部回复(3)
阿神

如果你只输入一个数字,然后直接按回车,这个interval就会被取消
如果你输入了两次就不会被取消,因为输入两次就有两个intervalId被赋值给了count,然后第二个覆盖了前一个,等于是说你只取消了最后一个

我在codepen上给你改了改,你看看是不是符合你的需求

黄舟

谢邀~

因为你每次keypress的时候都生成一个计时器(setInterval), 虽然count 赋值给了一个最新的, 当回车的时候, 把最新的count给清除了, 但是还有$('#user').val().length - 1个计时器没有清除.

巴扎黑

在第一个if里面,判断count是否已经有了,如果有了,就不要再重新生成一个setInterval

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号