定时器会返回一个数字值id,可以由clearInterval(id)或clearTimeout(id)来实现对对应定时器的清除。
setInterval()/setTimeout()BOM中的Window对象方法,以返回数字值id来清除定时器的排序位置存在一定的兼容性问题。通常采用一个变量接受定时器产生的返回值id,通过变量来这种方式来实现关闭定时器操作的兼容性。
chorme浏览器测试:
var i = 0; var timer = setInterval(function () { console.log(i + 'i'); i++; }, 1000) console.log(timer);//=>1,firefox浏览器可能显示为2,这是BOM中的兼容性问题 console.log(typeof timer);//=>'number'
直接采用定时器返回的数值ID关闭定时器的代码:(chrome[版本 73.0.3683.103(正式版本)(64 位)]测试有效)
var j=0; var a = setInterval(function () { console.log(j + 'j'); j++; }, 1000); clearInterval(1);
一般避免BOM中定时器返回数值ID直接使用,以免产生兼容性问题。避免这种兼容性使用定时器的案例:
<!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <title>cnblog头部轮播图</title> <meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no"> <style> </style> <script> </script> </head> <body> <input type='button' value='点击开启定时器' id='btn' /> <input type='button' value='点击关闭定时器' id='btn-close' /> <p id='content'></p> <script> var i = 0; var oBtn = document.getElementById('btn'); var oBtnC = document.getElementById('btn-close'); var oP = document.getElementById('content'); var timer = null; oBtn.onclick = function () { if(timer){ clearInterval(timer); } timer=setInterval(function () { oP.innerHTML += i + '<br/>'; i++; }, 1000); } oBtnC.onclick = function (){ clearInterval(timer); } </script> </body> </html>
测试时,以下版本浏览器的定时器返回数值ID以1为起始,一次后排。
Chrome[版本 73.0.3683.103(正式版本)(64 位)]
UC[版本6.2.4098.3]
Edge[Microsoft Edge 44.17763.1.0]测试。
但是兼容性问题浏览器:
fireFox[版本67.0.3 (32 位)]要在原定时器的序位的基础上加1。