JS中定时器的返回数值ID值


定时器会返回一个数字值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。

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM