Javascript 编写的一个红、黄、绿灯交替变亮

为了创建一个简单但功能完整的交通灯程序,我们将使用 HTML、CSS 和 JavaScript 来实现红、黄、绿三种颜色按照规定的顺序循环显示。这个例子将确保灯光按照红 -> 绿 -> 黄的顺序循环,并且可以调整每个灯光的持续时间以模拟真实的交通灯行为。

效果图

源代码

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>交通灯</title>
<link rel="stylesheet" href="styles.css">
<style>
	body {
	    display: flex;
	    justify-content: center;
	    align-items: center;
	    height: 100vh;
	    margin: 0;
	    background-color: #f0f0f0;
	}
	
	.traffic-light {
	    width: 100px;
	    background-color: #222;
	    padding: 20px;
	    border-radius: 10px;
	}
	
	.light {
	    width: 60px;
	    height: 60px;
	    margin: 10px auto;
	    border-radius: 50%;
	    background-color: #ddd;
	    transition: background-color 0.3s;
	}
	
	#red-light.active { background-color: red; }
	#yellow-light.active { background-color: yellow; }
	#green-light.active { background-color: green; }
</style>
</head>
<body>
<div class="traffic-light">
    <div id="red-light" class="light"></div>
    <div id="yellow-light" class="light"></div>
    <div id="green-light" class="light"></div>
</div>

<script >
// 获取所有灯泡元素
const redLight = document.getElementById('red-light');
const yellowLight = document.getElementById('yellow-light');
const greenLight = document.getElementById('green-light');

// 定义一个函数来激活指定的灯泡
function activateLight(light) {
    // 移除所有灯泡的 active 类
    [redLight, yellowLight, greenLight].forEach(l => l.classList.remove('active'));
    
    // 给指定的灯泡添加 active 类
    light.classList.add('active');
}

// 定义交通灯的状态顺序
const lightSequence = [redLight, yellowLight, greenLight];

// 当前索引
let currentIndex = 0;

// 创建一个间隔计时器来切换灯光
function startTrafficLight() {
    setInterval(() => {
        // 激活当前索引对应的灯泡
        activateLight(lightSequence[currentIndex]);
        
        // 更新索引到下一个状态
        currentIndex = (currentIndex + 1) % lightSequence.length;
    }, 2000); // 每 2 秒切换一次
}

// 开始交通灯循环
startTrafficLight();
	
</script>
</body>
</html>
相关推荐
candyTong28 分钟前
阿里开源 AI Code Review 工具:ocr review 的执行链路解析
javascript·后端·架构
铁皮饭盒1 小时前
TypeBox 比 Zod.js 校验 快10倍, 还兼容AI 工具调用, 他做对了什么?
前端·javascript·后端
To_OC10 小时前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
kyriewen12 小时前
面试官问你:“AI 能写 80% 的代码了,公司为什么还需要你?”
前端·javascript·面试
Goodbye15 小时前
从 Token 到 Embedding:LLM 核心基础深度解析
javascript·人工智能
用户9385156350715 小时前
工具调用背后:LLM 如何突破“缸中大脑”,操控真实世界?
javascript·人工智能
Goodbye15 小时前
从函数到智能:LLM Tool Use 深度解析
javascript·人工智能
半个落月15 小时前
大模型到底是怎么“调用工具”的?从一个 Node.js Demo 看懂 Tool Use
javascript·人工智能
烬羽15 小时前
中英文 token 数量差一倍?两段 JS 代码搞懂 LLM 底层是怎么"读"文字的
javascript·程序员·架构
山河木马15 小时前
矩阵专题1-怎么创建模型矩阵(uModelMatrix)
javascript·webgl·计算机图形学