JS之setTimeOut与clearTimeOut
2018-12-02 06:14:39来源:博客园 阅读 ()
小练习1:针对HTML,分别使用 setTimeout 和 setInterval 实现以下功能:
- 点击按钮时,开始改变 fade-obj 的透明度,开始一个淡出(逐渐消失)动画,直到透明度为0
- 在动画过程中,按钮的状态变为不可点击
- 在动画结束后,按钮状态恢复,且文字变成“淡入”
- 在 按钮显示 淡入 的状态时,点击按钮,开始一个“淡入”(逐渐出现)的动画,和上面类似按钮不可点,直到透明度完全不透明
- 淡入动画结束后,按钮文字变为“淡出”
- 暂时不要使用 CSS animation (以后我们再学习)
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>与页面对话4</title> </head> <body> <div id="fade-obj" style="width:300px;height:300px;background:#000;opacity: 1;"></div> <button id="fade-btn" onclick="beLowOpa()">淡出</button> <script> var opaCount = 1; var btn= document.getElementById("fade-btn"); function beLowOpa() { btn.disabled = true; opaCount -= 0.05; document.getElementById("fade-obj").style.opacity = opaCount; var t = setTimeout("beLowOpa()", 100); if (opaCount <= 0) { clearTimeout(t); btn.disabled = false; btn.innerHTML = "淡入"; btn.addEventListener("click", beHighOpa); } } function beHighOpa() { btn.disabled = true; opaCount += 0.05; document.getElementById("fade-obj").style.opacity = opaCount; var t = setTimeout("beHighOpa()", 100); if (opaCount >= 1) { clearTimeout(t); btn.disabled = false; btn.innerHTML = "淡出"; btn.addEventListener("click", beLowOpa); } } </script> </body> </html>
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
下一篇:写小程序的一些小坑
- JS项目练习之求和(包含正则表达式验证) 2019-08-14
- css, js 项目练习之网页换肤 2019-08-14
- setInterval和setTImeout中的this指向问题 2019-05-22
- setTimeout第三个参数 2019-05-16
- 宏任务和微任务:setTimeout和Promise执行顺序 2019-05-10
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash