785-788---BOM(定时器(setTimeout() 定时器),案例:5秒后自动关闭广告,停止 setTimeout() 定时器,setInterval() 定时器)

BOM

3 定时器

eg: 在这里插入图片描述

此处轮播图有两张,它每隔一段时间就会播放下一个图片,这些跟时间打交道的效果,我们便可以使用定时器

3.1 两种定时器

window对象给我们提供了2个非常好用的方法定时器。

  • setTimeout()
  • setInterval()

3.2 setTimeout() 定时器

window.setTimeout (调用函数,[延迟的毫秒数]);

setTimeout()方法用于设置一个定时器,该定时器在定时器到期后执行调用函数。

注 意 : \color{red}{注意:} :

  1. window可以省略。
  2. 这个调用函数可以 直 接 写 函 数 , 或 者 写 函 数 名 \color{red}{直接写函数 , 或者写函数名} ,或者采取字符串‘ 函 数 名 ( ) \color{DodgerBlue}{函数名()} () '三种形式。 第三种不推荐
  3. 延迟的毫秒数省略默认是0 ,如果写 , 必须是毫秒。
  4. 因为定时器可能有很多,所以我们经常给定时器赋值一个标识符。

eg. 08-定时器之setTimeout.html

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
  <script>
    //1. setTimeout
    // 语法规范: window . setTimeout(调用函数,延时时间);
    // 1 这个window在调用的时候可以省略
    // 2 这个延时时间单位是毫秒  但是可以省略 如果省略默认的是0
    // 3 这个调用函数可以直接写函数  还可以写函数名  还有一个写法 '函数名()'
    // 4 页面中可能有很多的定时器  我们经常给定时器加标识符  (名字)
    // setTimeout(function() {
    //   console.log('时间到了');
    // }, 2000);    // 2000ms = 2s   到了两秒钟之后就去调用这个函数
    function callback() {
      console.log('爆炸了');
    }
    var timer1 = setTimeout(callback,3000);  // 3秒钟之后调用函数
    var timer2 = setTimeout(callback,5000);  // 5秒钟之后调用函数
    // setTimeout('callback()',3000);  // 3秒钟之后调用函数  但是不提倡这个方法,上面的那个方法就很好 简洁
  

  </script>
</body>
</html>

setTimeout() 这个调用函数我们也称为 回 调 函 数 c a l l b a c k \color{red}{回调函数callback} callback

普通函数是按照代码顺序直接调用。

而这个函数, 需 要 等 待 \color{red}{需要等待} 时间 , 时间到了才去调用这个函数 , 因此称为回调函数。

简单理解 : 回调,就是回头调用的意思。上一 件事干完 , 再回头再调用这个函数。

以前学的element.onclick = function(){}或者element. addEventListener(“click” , fn);里面的函数也是回调函数。

案例:5秒后自动关闭广告

案例分析

  1. 核心思路 : 5秒之后 , 就把这个广告隐藏起来
  2. 用定时器setTimeout

素材图(可以换别的,注意图片路径)在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
  <img src="images/ad.png" alt="" class="ad">
  <script>
    var ad = document.querySelector('.ad');
    setTimeout(function() {
      ad.style.display = 'none';
    },5000);
  </script>
</body>
</html>

效果:广告显示五秒之后就会消失

3.3 停止 setTimeout() 定时器

window.clearTimeout(timeoutID)

clearTimeout ()方法取消了先前通过调用setTimeout ()建立的定时器。

注意:

  1. window可以省略。
  2. 里面的参数就是定时器的标识符。

3.4 setInterval() 定时器

window.setInterval(回调函数,[间隔的毫秒数]);

setInterval0方法重复调用一个函数,每隔这个时间,就去调用一次回调函数。

注 意 : \color{red}{注意:} :

  1. window可以省略。
  2. 这个调用函数可以 直 接 写 函 数 , 或 者 写 函 数 名 \color{red}{直接写函数,或者写函数名} ,或者采取字符串 ′ 函 数 名 ( ) ′ \color{blue}{'函数名()'} ()三种形式。
  3. 间隔的毫秒数省略默认是0 ,如果写,必须是毫秒,表示每隔多少毫秒就自动调用这个函数。
  4. 因为定时器可能有很多,所以我们经常给定时器赋值一个标识符。

eg 11-定时器之serinterval.html

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
  <script>
    // 1 setInterval
    // 语法规范: windows.setInterval(调用函数, 延时时间);
    setInterval(function() {
      console.log('继续输出'); 
    }, 1000);   // 每隔1s调用这个函数
    // 2 setTimeout 延时时间到了,就去调用这个回调函数,只调用一次  就结束了这个定时器
    // 3 setInterval 每隔这个延时时间,就去调用这个回调函数  会调用很多次  重复调用这个函数
    
  </script>
</body>
</html>
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值