异步(实现红绿灯)
三种方式:callback,Promise,async/await
代码实现:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<style>
div{
background-color: gray;
display: inline-block;
margin: 30;
width: 100px;
height: 100px;
border-radius: 50px;
}
.green.light{
background-color: green;
}
.yellow.light{
background-color: yellow;
}
.red.light{
background-color: red;
}
</style>
<div class="green"></div>
<div class="yellow"></div>
<div class="red"></div>
<button id="next">
next
</button>
<script>
function green(){
let lights = document.getElementsByTagName("div")
for (var i =0;i<3;i++){
lights[i].classList.remove("light")
}
document.getElementsByClassName("green")[0].classList.add('light')
}
function yellow(){
let lights = document.getElementsByTagName("div")
for (var i =0;i<3;i++){
lights[i].classList.remove("light")
}
document.getElementsByClassName("yellow")[0].classList.add('light')
}
function red(){
let lights = document.getElementsByTagName("div")
for (var i =0;i<3;i++){
lights[i].classList.remove("light")
}
document.getElementsByClassName("red")[0].classList.add('light')
}
function sleep(t){
return new Promise((resolve,reject)=>{
setTimeout(resolve,t)
})
}
function happen(element,eventName){
return new Promise((res,rej)=>{
element.addEventListener(eventName,res,{once:true})
})
}
async function start(){
while(true){
green()
await happen(document.getElementById("next"),'click')
yellow()
await happen(document.getElementById("next"),'click')
red()
await happen(document.getElementById("next"),'click')
}
}
start()
</script>
</body>
</html>