【JavaScript】定时器详解

news2025/1/11 14:55:41

文章目录

  • 【JavaScript】定时器详解
    • 一. 定时器分类
    • 二. 定时器的使用
    • 三. 案例:实现抽奖效果
      • 样式一
      • 样式二

【JavaScript】定时器详解

一. 定时器分类

  1. 延迟定时器

    setTimeout(function(){}, 毫秒数)
    

    作用:隔一段时间之后执行

  2. 间隔定时器

    setInterval(function(){}, 毫秒数)
    

    作用:每隔一段时间执行一次

  3. 关闭定时器

    clearTimeout(定时器)
    clearInterval(定时器)
    

    :虽然关闭定时器的方式有两种,且没什么太大的区别,但是还是建议对应着使用。(如:setInterval ==> clearInterval(定时器))

二. 定时器的使用

  1. 延迟定时器

    setTimeout(function () {
        console.log("执行了。。。");
    }, 2000); // 2s 之后,控制台输出:执行了。。。
    
  2. 间隔定时器

    setInterval(function () {
        console.log("执行了...");
    }, 2000);
    
  3. 关闭定时器

    var t1 = setTimeout(function () {
        console.log("执行了延迟定时器");
    }, 1000);
    clearInterval(t1); // 关闭定时器
    

三. 案例:实现抽奖效果

样式一

HTML代码

<div id="box">开始抽奖</div>

CSS代码

div {
    width: 500px;
    height: 100px;
    border: 2px solid #000;
    margin: 100px auto;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 50px;
}

JavaScript代码

// 奖品
var arr = [
    "皮筋一个",
    "辣条一包",
    "谢谢惠顾",
    "包子一个",
    "卡片一张",
    "发夹一个",
    "手机模型",
    "空头支票",
    "皮球一个",
    "果冻一个"
];
// 随机生成 0~arr.length-1 随机数
function randNum(min, max) {
    return Math.round(Math.random() * (max - min)) + min;
}
// 标记思维
var flag = false;
t = null;
// 点击开始
box.onclick = function() {
    if (!flag) {
        // 每个一段时间进行内容切换
        t = setInterval(function() {
            // 调用生成随机数函数
            var num = randNum(0, arr.length - 1);
            // 将生成的随机数当做数组的索引,显示数组的值
            var res = arr[num];
            // 将对应的值显示到页面中
            box.innerHTML = res;
        }, 100);
        flag = true;
    } else {
        clearInterval(t);
        flag = false;
    }
}

效果图

请添加图片描述

样式二

HTML代码

<div id="box">开始抽奖</div>
<button id="btn1">开始</button>
<button id="btn2">停止</button>

CSS代码

div {
    width: 500px;
    height: 100px;
    border: 2px solid #000;
    margin: 100px auto;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 50px;
}

body {
    text-align: center;
}

JavaScript代码

// 随机生成 0~arr.length-1 随机数
function randNum(min, max) {
    return Math.round(Math.random() * (max - min)) + min;
}
// 奖品
var arr = [
    "皮筋一个",
    "辣条一包",
    "谢谢惠顾",
    "包子一个",
    "卡片一张",
    "发夹一个",
    "手机模型",
    "空头支票",
    "皮球一个",
    "果冻一个"
];
// 随机生成 0~arr.length-1 随机数
function randNum(min, max) {
    return Math.round(Math.random() * (max - min)) + min;
}
t = null;
// 点击开始
btn1.onclick = function() {
    // 防止点击开始重复触发
    if (t) {
        return;
    }
    // 每个一段时间进行内容切换
    t = setInterval(function() {
        // 调用生成随机数函数
        var num = randNum(0, arr.length - 1);
        // 将生成的随机数当做数组的索引,显示数组的值
        var res = arr[num];
        // 将对应的值显示到页面中
        box.innerHTML = res;
    }, 100);

}
btn2.onclick = function() {
    clearInterval(t);
    t = null;
}

效果图

请添加图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/127449.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【UE4 第一人称射击游戏】18-添加角色换弹时的动作

上一篇&#xff1a; 【UE4 第一人称射击游戏】17-重写换弹逻辑 本篇效果&#xff1a; 步骤&#xff1a; 1.打开“SWAT_AnimBP”&#xff0c;在动画图表中&#xff0c;添加一个名为“Reloading”的状态 完善过渡规则的连线 双击打开“Reloading”&#xff0c;添加换弹动画 2…

Spring Security 401 问题解决

背景 &#xff1a; 微服务接口调用的时候报错&#xff0c;原来有一个rest服务用的不多&#xff0c;平时用的都是一些基础的服务&#xff0c;然后客户需要我们开放一个外部接口给他们&#xff0c;然后我寻思着就在这里面写接口。然后调用的时候就报如下的错。 后面跟踪源码发现 …

window上完全卸载oracle

Window上彻底卸载oracle 关闭oracle服务-----开始-----&#xff1e;设置-----&#xff1e;控制面板-----&#xff1e;管理工具-----&#xff1e;服务----->停止所有Oracle服务。 卸载软件------开始------所有程序------Oracle - OraDb11g_home1------Oracle 安装产品-----…

传统CV算法——边缘检测

文章目录传统CV算法-边缘检测第一章 概述1. **边缘检测概述**1.1 **认识边缘**1.2 **边缘检测的概念**1.3 **边缘检测的基本方法**1.4 **边缘检测算子的概念**1.5 **常见的边缘检测算子**2. **用梯度算子实现边缘检测的原理**2.1 **认识梯度算子**2.2 **梯度的衡量**2.3 **使用…

3D打印机的调平问题

快打完第五批料了&#xff0c;也算是有一些仅限于PLA以及PLA&#xff0b;耗材心得 3D打印机调平的简易方式有哪些&#xff1f; 在3D打印机中&#xff0c;打印平台作为模型的承载平台&#xff0c;如果有偏差&#xff0c;那么在后期的打印中&#xff0c;必然会导致细节的出现差…

[从零开始]用python制作识图翻译器·一

AlsoEasy-RecognitionTranslator前言需求分析应用场景需求提取需求补充竞品分析QQ识图百度翻译UU翻译器小结功能实现前言 这是我的毕设作品。当时玩了《人狼村之谜》觉得很惊艳&#xff0c;所以想玩一下该社的别的作品&#xff1a;《D.M.L.C.》。但是苦于没有熟肉&#xff0c;自…

vue2中使用VantUI

Vant 是一个轻量、可靠的移动端组件库 目前 Vant 官方提供了 Vue 2 版本、Vue 3 版本和微信小程序版本&#xff0c;并由社区团队维护 React 版本和支付宝小程序版本。 Vant 2 - Mobile UI Components built on Vue 第一步&#xff1a;安装该组件库 在现有项目中使用 Vant 时&a…

Azure 深入浅出[3]: 如何在MS Visio里面画专业的Azure技术架构图?

1.前言 笔者最近在研究Azure&#xff0c;需要画Azure的技术架构图&#xff1b;画Azure架构图的方法很多&#xff0c;有在线的工具&#xff0c;有基于Azure的PPT模板&#xff0c;同时也有笔者这样选择用最传统的微软的工具&#xff1a;MS Visio来绘图。那么在MS Visio里面如何绘…

设计模式六大原则

设计模式六大原则 1.单⼀职责( ⼀个类和⽅法只做⼀件事 ) 不遵守单一职责原则 模拟不同用户观看视频&#xff0c;先一把梭哈&#xff0c;所有用户观看视频的服务全部都写道一块 public class ApiTest {public static void main(String[] args) {VideoUserService service …

干货丨FPGA零基础学习,入门必看!

看到不少同学后台进行提问&#xff1a;FPGA如何入门&#xff1f;怎么学习&#xff1f;其实对于新人来说&#xff0c;FPGA的学习需要了解的东西还是非常多&#xff0c;下面IC修真院就带大家一起来了解一下吧。 FPGA简介 FPGA普遍用于实现数字电路模块&#xff0c;用户可对FPGA…

Codeforces Round #666 (Div. 1) A. Multiples of Length

Problem - A - Codeforces翻译&#xff1a; 您将得到一个由&#x1d45b;个整数组成的数组&#x1d44e;。 你想要让&#x1d44e;的所有元素都等于零&#xff0c;只需执行以下操作三次: 选择一个段&#xff0c;对于这个段中的每一个数字&#xff0c;我们可以给它加上&#…

后疫情时代语音机器人和大数据的发展前景

语音机器人可以通过自动化流程和提供快速、准确的信息来帮助企业降低成本、增加效率。具体来说&#xff0c;企业可以使用语音机器人来完成以下任务&#xff1a; 客户服务&#xff1a;语音机器人可以自动处理客户查询和请求&#xff0c;从而节省人力成本。数据录入&#xff1a;…

Mask R-CNN论文讲解

目录&#xff1a;Mask R-CNN论文理解一、摘要二、介绍三、Mask R-CNN四、RoIAlign五、Network Architecture六、训练一、摘要 论文提出了一个概念上简单、灵活和通用的对象实例分割框架。有效地检测图像中的对象&#xff0c;同时为每个实例生成高质量的分割掩码。 方法被称为…

Python量化交易06——Fama-French三因子模型(Rmt,SMB,HML)

参考书目:深入浅出Python量化交易实战 本次带来的是著名的获得了诺贝尔奖的三因子模型。 因子模型介绍 Fama和French从可以解释股票收益率的众多因素中提取出了三个重要的影响因子&#xff0c;即市场风险溢酬因子、市值因子和账面市值比因子B/M Ratio&#xff0c;仿照CAPM模型…

测试用例能带来什么

通过测试用例&#xff0c;我们都能获得些什么呢? 1、测试团队的质量判断。例如&#xff0c;测试用例的覆盖率。我们只需要去把所有的valid的功能bug去做一个分析&#xff0c;用所有在测试用例覆盖范围之外的bug数/总bug数&#xff0c;就可以作为测试用例覆盖率使用。一个良好的…

【css】深入解析CSS (4)网格布局

设置为display: grid的元素成为一个网格容器&#xff08;grid container&#xff09;。它的子元素则变成网格元素&#xff08;grid items&#xff09;。 1.网格的组成部分&#xff1a; grid-template-columns和grid-template-rows定义了网格轨道 grid-template-columns:1fr 1f…

STM32/51单片机实训day4——RFID工作原理(一)理论

目录 一、RFID的定义 二、RFID的起源和发展 三、RFID的组成 3.1 标签 3.2 读写器 3.3 天线 四、RFID系统分类 4.1 根据标签的供电方式 4.2 根据工作频率 五、RFID系统工作原理 5.1 读写器 5.2 标签 5.3 中间件 内 容&#xff1a;能够读取RFID卡S50的ID——编程…

如何利用 xUnit 框架对测试用例进行维护?

1、xUnit 是什么 先看 Wikipedia 上的解释&#xff1a; xUnit 是一系列测试框架的统称&#xff0c;最开始来源于一个叫做 Smalltalk 的 SUnit 框架&#xff0c;现在各种面向对象的语言&#xff0c;如 Java、Python 的鼻祖就是 Smalltalk&#xff0c;后来这些语言都借助了 Suni…

Win10 开机突然蓝屏错误代码0xc0000001安全模式也进不了,不用重装系统怎么修复?(已解决)

环境: Win 10专业版 HP480G7 问题描述: Win10 开机突然蓝屏错误代码0xc0000001,前一天好好的,F8安全模式也进不了,不用重装系统怎么修复? 解决方案: 方法一 1.重启F8进入里面的安全模式(本案例进不了) 方法二 (解决本案例) 1.使用系统安装U盘,需提前做好…

力扣(LeetCode)220. 存在重复元素 III(C++)

滑动窗口有序集合 维护滑动窗口&#xff0c;向右扩大右窗口&#xff0c;新数加入有序集合&#xff0c;题目要求abs(nums[i] - nums[j]) < t &#xff0c;找两数之差的绝对值小于t&#xff0c;相当于在窗口里找大小尽可能接近的两个数&#xff0c;固定其中一个数(新数)&…