杨校老师课堂之JavaScript定时器案例的红绿灯设计--原始写法

news2024/12/25 9:24:05

主要介绍了JavaScript定时器设置、使用与倒计时案例,详细分析了javascript定时器的设置、取消、循环调用并附带一个倒计时功能应用案例,需要的朋友可以参考下:

运行效果图:

在这里插入图片描述

配套视频课程

基于JavaScript的红绿灯设计


演示代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta author="Mryang">
    <meta keyword="杨校老师课堂_CSDN地址——https://mryang.blog.csdn.net/">
    <title>基于JavaScript的红绿灯设计</title>
</head>
<style>
    .box{
        width: 310px;
        height: 80px;
        border: 2px solid #ccc;
        border-radius: 15px;
        margin: 0 auto;
    }
    .box div{
        width: 60px;
        height: 60px;
        border-radius: 50%;
        border: 1px solid #666;
        float: left;
        margin-left: 13px;
        margin-top: 8px;
    }
    .box .count{
        width: 60px;
        height: 60px;
        margin-left: 13px;
        margin-top: 8px;
        font-size: 250%;
        line-height: 60px;
        text-align: center;
        border: 0;
    }
    /*  继续编写 颜色*/
    .gray{
        background-color: #eeeeee;
    }
    .red{
        background-color: red;
    }
    .yellow{
        background-color: yellow;
    }
    .green{
        background-color: #25FF00 ;
    }
</style>
<body>
    <!--外层的大盒子-->
    <div class="box">
        <!--1. 红灯-->
        <div id="red"></div>
        <!--2. 黄灯-->
        <div id="yellow"></div>
        <!--3. 绿灯-->
        <div id="green"></div>
        <!--4. 倒计时-->
        <div id="count" class="count"></div>
    </div>
</body>
</html>
<script type="text/javascript">
    // 1. 网页一经加载,显示为绿色,其次为黄色、最后变为红色
    window.onload = function () {
        // 1.1 默认展示为绿色
        var defaultColor = 'green';

        // 1.2 通过调用【更改颜色】的方法进行切换颜色并实现数字的倒计时显示,参数默认为颜色的色调即defaultColor
        changeColor(defaultColor);

    }
    // 定义 倒计时的变量,初始化值为 空
    var timeout = null;
    // 定义临时变量 number 来存储 倒计时的数字,用于拼接 09
    var number = null;

    // 定义变量timer 用于 接受 定时器,并且进行清楚定时器
    var  timer = null;

    //2. 定义方法: 更改颜色
    function changeColor(lightColor) {
        // 2.1 因为不确定传入的颜色是什么颜色,所以需要做个判断:
        if(lightColor == 'green'){
            //alert('传入颜色成功,颜色刚好是:' + lightColor)
            // 绿色倒计时 时长为 35s
            timeout = 35;
            // alert('绿色倒计时 时长为:' + timeout)
            // 绿灯时: 三个的颜色为  灰色  灰色  绿色 35
            document.getElementById("green").className = 'green';
            document.getElementById("yellow").className = 'gray';
            document.getElementById("red").className = 'gray';
            // 清除定时器
            clearInterval(timer)
            // 调用定时器
            timer = setInterval(function () {
                // 处理 倒计时的表达式 数值小于0
                if(timeout <= 0){
                    // 当倒计时为0 ,进入颜色的更替
                    changeColor('yellow');
                }
                // 使用number 变量 进行接受 timeout--
                number = timeout--;
                document.getElementById("count").innerText = (number < 10) ? ('0' + number) :number;
            },1000);
        }
        if(lightColor == 'yellow'){
            //alert('传入颜色成功,颜色刚好是:' + lightColor)
            // 黄色倒计时 时长为 5s
            timeout = 5;
            // alert('黄色倒计时 时长为:' + timeout)
            // 黄灯时: 三个的颜色为  灰色  黄色  灰色 5
            document.getElementById("green").className = 'gray';
            document.getElementById("yellow").className = 'yellow';
            document.getElementById("red").className = 'gray';
            // 清除定时器
            clearInterval(timer)
            // 调用定时器
            timer = setInterval(function () {
                // 处理 倒计时的表达式 数值小于0
                if(timeout <= 0){
                    // 当倒计时为0 ,进入颜色的更替
                    changeColor('red');
                }
                // 使用number 变量 进行接受 timeout--
                number = timeout--;
                document.getElementById("count").innerText = (number < 10) ? ('0' + number) :number;
            },1000);
        }
        if(lightColor == 'red'){
            //alert('传入颜色成功,颜色刚好是:' + lightColor)
            // 红色倒计时 时长为 20s
            timeout = 20;
            // alert('红色倒计时 时长为:' + timeout)
            // 红灯时: 三个的颜色为  红色  灰色  灰色 20
            document.getElementById("green").className = 'gray';
            document.getElementById("yellow").className = 'gray';
            document.getElementById("red").className = 'red';
            // 清除定时器
            clearInterval(timer)
            // 调用定时器
            timer = setInterval(function () {
                // 处理 倒计时的表达式 数值小于0
                if(timeout <= 0){
                    // 当倒计时为0 ,进入颜色的更替
                    changeColor('green');
                }
                // 使用number 变量 进行接受 timeout--
                number = timeout--;
                document.getElementById("count").innerText = (number < 10) ? ('0' + number) :number;
            },1000);
        }
    }
</script>

在这里插入图片描述

作者: 杨校

出处: https://mryang.blog.csdn.net

分享是快乐的,也见证了个人成长历程,文章大多都是工作经验总结以及平时学习积累,基于自身认知不足之处在所难免,也请大家指正,共同进步。

本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出, 如有问题, 可邮件(397583050@qq.com)咨询

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

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

相关文章

《Keras深度学习:入门、实战与进阶》之印第安人糖尿病诊断

本文摘自《Keras深度学习&#xff1a;入门、实战与进阶》。 1、数据理解 本节使用Pima Indians糖尿病发病情况数据集。该数据集最初来自国家糖尿病/消化/肾脏疾病研究所。数据集的目标是基于数据集中包含的某些诊断测量来诊断性的预测患者是否患有糖尿病。数据集由多个医学预…

python+django大学生成绩综合考评系统pycharm项目

开发语言&#xff1a;Python 框架&#xff1a;django Python版本&#xff1a;python3.7.7 数据库&#xff1a;mysql 数据库工具&#xff1a;Navicat11 开发软件&#xff1a;PyCharm 通常 一个Django model 对应一张数据表&#xff0c;model是以类的形式表现的 实现了ORM 对象…

Unity SRP自定义渲染管线学习2.2: 合批(Batching) SRP Batcher

接下来我们要来学习下自定义渲染管线中的合批&#xff0c;这一节主要学习SRP Batcher 每一次的Draw Call都需要CPU和GPU之间的通信&#xff0c;如果有大量的数据需要从CPU发送到GPU中&#xff0c;那GPU就可能因为等待数据而浪费时间&#xff0c;而CPU会因为忙于发送数据导致无…

第五章:Windows server加域

加入AD域&#xff1a;教学视频&#xff1a;https://www.bilibili.com/video/BV1xM4y1D7oL/?spm_id_from333.999.0.0首先我们选择一个干净的&#xff0c;也就是新建的没动过的Windows server虚拟机。我们将DNS改成域的ip地址&#xff0c;还要保证它们之间能ping的通&#xff0c…

详细解读ChatGPT:如何调用ChatGPT的API接口到官方例子的说明以及GitHub上的源码应用

文章目录1. 解读ChatGPT1.1 词语解释1.2 功能解读2. GitHub上ChatGPT的应用源码3. 调用ChatGPT的API4. 官方例子说明5. 集成ChatGPT自ChatGPT出来到如今&#xff0c;始终走在火热的道路上&#xff0c;如今日活用户破亿&#xff0c;他为何有如此大的魅力&#xff0c;深受广大用户…

opencv保存图片

大家好&#xff0c;我是csdn的博主&#xff1a;lqj_本人 这是我的个人博客主页&#xff1a; lqj_本人的博客_CSDN博客-微信小程序,前端,python领域博主lqj_本人擅长微信小程序,前端,python,等方面的知识https://blog.csdn.net/lbcyllqj?spm1011.2415.3001.5343哔哩哔哩欢迎关注…

SIGIR22:User-controllable Recommendation Against Filter Bubbles

User-controllable Recommendation Against Filter Bubbles 摘要 推荐系统经常面临过滤气泡的问题&#xff1a;过度推荐基于用户特征以及历史交互的同质化项目。过滤气泡将会随着反馈循环增长&#xff0c;缩小了用户兴趣。现有的工作通常通过纳入诸如多样性和公平性等准确性之…

AcWing、第 90 场周赛:4806. 首字母大写、4807. 找数字、4808. 构造字符串(C++)

目录 4806. 首字母大写 题目描述&#xff1a; 实现代码&#xff1a; 4807. 找数字 题目描述&#xff1a; 实现代码&#xff1a; 回溯&#xff08;超时&#xff09;&#xff1a; 原理思路&#xff1a; 贪心&#xff1a; 原理思路&#xff1a; 4808. 构造字符串 问题…

53. 最大子数组和

文章目录题目描述暴力法动态规划法分治法参考文献题目描述 给你一个整数数组 nums &#xff0c;请你找出一个具有最大和的连续子数组&#xff08;子数组最少包含一个元素&#xff09;&#xff0c;返回其最大和。 子数组 是数组中的一个连续部分。 示例 1&#xff1a; 输入&…

JavaScript中数组常用的方法

文章目录前言常用数组方法1、 join( )2、push&#xff08;&#xff09;与 pop&#xff08;&#xff09;3、shift&#xff08;&#xff09;与 unshift&#xff08;&#xff09;4、sort&#xff08;&#xff09;5、reverse&#xff08;&#xff09;6、slice&#xff08;&#xff…

代码随想录算法训练营第二十七天 | 93.复原IP地址,78.子集,90.子集II

一、参考资料复原IP地址题目链接/文章讲解&#xff1a;https://programmercarl.com/0093.%E5%A4%8D%E5%8E%9FIP%E5%9C%B0%E5%9D%80.html 视频讲解&#xff1a;https://www.bilibili.com/video/BV1XP4y1U73i/子集题目链接/文章讲解&#xff1a;https://programmercarl.com/0078.…

乐观锁、雪花算法、MyBatis-Plus多数据源

乐观锁、雪花算法、MyBatis-Plus多数据源e>雪花算法2、乐观锁a>场景b>乐观锁与悲观锁c>模拟修改冲突d>乐观锁实现流程e>Mybatis-Plus实现乐观锁七、通用枚举a>数据库表添加字段sexb>创建通用枚举类型c>配置扫描通用枚举d>测试九、多数据源1、创建…

电子学会2022年12月青少年软件编程(图形化)等级考试试卷(二级)答案解析

青少年软件编程&#xff08;图形化&#xff09;等级考试试卷&#xff08;二级&#xff09; 一、单选题(共25题&#xff0c;共50分) 1. 一个骰子&#xff0c;从3个不同角度看过去的点数如图所示&#xff0c;请问5的对面是什么点数&#xff1f;&#xff08; &#xff09; …

数据库(单表查询)

素材&#xff1a; 表名&#xff1a;worker-- 表中字段均为中文&#xff0c;比如 部门号 工资 职工号 参加工作 等 CREATE TABLE worker ( 部门号 int(11) NOT NULL, 职工号 int(11) NOT NULL, 工作时间 date NOT NULL, 工资 float(8,2) NOT NULL, 政治面貌 varchar(10) NOT NUL…

【C语言技能树】程序环境和预处理

Halo&#xff0c;这里是Ppeua。平时主要更新C语言&#xff0c;C&#xff0c;数据结构算法......感兴趣就关注我吧&#xff01;你定不会失望。 &#x1f308;个人主页&#xff1a;主页链接 &#x1f308;算法专栏&#xff1a;专栏链接 我会一直往里填充内容哒&#xff01; &…

一文掌握,单机Redis、哨兵和Redis Cluster的搭建,建议收藏

本篇文章讲述了 Redis 单机环境、主备、哨兵 Sentinel 模式以及 Redis Cluster 集群模式下的操作步骤&#xff0c;关于这些操作我们没必要死记硬背&#xff0c;只需要总结下来&#xff0c;下次使用直接拿出来就好。建议当作操作手册收藏。安装单实例 Redis编译Redis1.下载Redis…

小白都能学会的红帽(RedHat8)RHEL8系统安装实战

文章目录前言一. 实验环境二. 安装虚拟机三. 安装操作系统四. 系统安装成功后的操作总结前言 本文是应一位大佬的提议&#xff0c;建议我写写红帽系列&#xff0c;centos8已经不维护了&#xff0c;centos7 维护到2024年6月30日&#xff0c; 也就是明年的事情了&#xff0c;所以…

【Flutter入门到进阶】Dart基础篇---基于对比Java学习Dart

1 Dart语言特性 1.1 简介 1.1.1 说明 2011年10月&#xff0c;在丹麦召开的 GOTO 大会上&#xff0c;Google 发布了一种新的编程语言 Dart 。如同 Kotlin 和 Swift 的出现&#xff0c;分别是为了解决 Java 和 Objective-C 在编写应用程序的一些实际问题一样&#xff0c;Dart 的…

算法笔记(二)—— 认识N(logN)的排序算法

递归行为的时间复杂度估算 整个递归过程是一棵多叉树&#xff0c;递归过程相当于利用栈做了一次后序遍历。 对于master公式&#xff0c;T(N)表明母问题的规模为N&#xff0c;T(N/b)表明每次子问题的规模&#xff0c;a为调用次数&#xff0c;加号后面表明&#xff0c;除去调用之…

八股初始:RocketMQ

一、消息队列介绍 消息队列是什么 对于 MQ 来说&#xff0c;其实不管是 RocketMQ、Kafka 还是其他消息队列&#xff0c;它们的本质都是&#xff1a;一发一存一消费。 将 MQ 掰开了揉碎了来看&#xff0c;都是「一发一存一消费」&#xff0c;再直白点就是一个「转发器」。生产…