zoukankan      html  css  js  c++  java
  • JavaScript之setInterval() 函数

    定义和用法

    setInterval() 方法可按照指定的周期(以毫秒计)来调用函数或计算表达式。

    setInterval() 方法会不停地调用函数,直到 clearInterval() 被调用或窗口被关闭。由 setInterval() 返回的 ID 值可用作 clearInterval() 方法的参数。

    语法

    setInterval()函数的语法如下:

    setInterval ( code, milliseconds[, args...] )

    参数 描述
    code 需要执行的函数或js代码
    milliseconds 执行函数或代码的间隔时间,单位为毫秒
    args 可选参数用于给被调用的函数传递参数,参数可以有多个
    返回值

    setInterval()函数将返回一个标识符 ID,这个 ID 是唯一的(一般是整数,从 1 开始,每调用一次 setInterval() 就加 1)。

    如果需要 setInterval() 执行的函数或代码尚未执行,我们可以通过 clearInterval() 函数来取消该执行操作,clearInterval() 需要接收一个参数,这个参数就是 setInterval() 返回的标识符ID。

    如果参数code执行的是一个函数则可以直接使用函数名称或者匿名函数作为参数。如果函数需要参数,我们可以通过setInterval()的可选参数为其传递相应的参数。

    //该函数不需要参数
    function test(){
        alert("测试");
    }
    // 每隔5秒钟就弹出提示信息"测试"。
    setInterval(test, 5000);
    
    // 使用匿名函数作为参数,每隔5秒钟就输出控制台信息"测试2"。
    setTimeout(function(){
        console && console.log("测试2");  
    }, 5000);
    
    // 该函数需要两个参数
    function sayHello(name, age){
        alert("我叫" + name + ",今年" + age + "岁!");
    }
    //每隔5秒钟就弹出提示信息"我叫CodePlayer,今年18岁!"。
    setInterval(sayHello, 5000, "CodePlayer", 18);

    我们可以使用clearInterval()函数来取消setInterval()设定的定时操作。

    function test(){
        alert("测试");
    }
    
    // 每隔5秒钟就弹出提示信息"测试"。
    var intervalID = setInterval(test, 5000);
    
    // 取消该定时设置
    clearInterval(intervalID);

    此外,请一定注意:setInterval()的定时代码是在全局作用域下执行的,因此你不能在定时代码中调用某些局部变量,否则可能会报错。

    // 以下是错误的用法,setInterval的定时代码无法调用局部变量site
    function foo(){
        var site = "CodePlayer";
        setInterval('alert(site);', 5000);   
    }
    foo();
    
    var x = 15;
    function bar(){
        var x = 18;
        setInterval('alert(x);', 5000); // 15
    }
    // 由于setInterval的定时代码是在全局作用域下执行的,因此这里的x为15
    bar();

    你可以通过以下方法来间接解决上述作用域问题:

    // 省略var修饰符,使用全局变量代替局部变量
    function foo1(){
        site = "CodePlayer 1";
        setInterval('alert(site);', 5000);   
    }
    foo1();
    
    // 不使用变量,直接传递变量的值
    function foo2(){
        var site = "CodePlayer 2";
        setInterval('alert("' + site + '");', 5000);
    }
    foo2();
    
    // 延长作用域链,使其能够访问到该函数作用域
    function foo3(){
        var site = "CodePlayer 3";
        setInterval(function(){
            alert(site);
        }, 5000);   
    }
    foo3();
    
    // 调用指定的函数,并给函数传递相应的参数
    function callback(msg){
        alert(msg);
    }
    function foo4(){
        var site = "CodePlayer 4";
        setInterval(callback, 5000, site);   
    }
    foo4();
  • 相关阅读:
    一小段代码体现出的编程艺术
    2013年:第十一届软交会今天开始
    干掉baidu地图Logo的CSS
    编程语言历史,你属于几零后?
    WebServer实现SQL数据库百度坐标转换转化的算法
    使用Nginx代理Ext.net2.0异步请求报错问题
    PostgreSQL9.3新增的json_populate_recordset函数使用问题
    坐标转换服务笔录
    关于extjs中文乱码和emptyText的问题
    百度地图Polyline画直线BUG
  • 原文地址:https://www.cnblogs.com/liyqiang/p/6902544.html
Copyright © 2011-2022 走看看