资讯专栏INFORMATION COLUMN

原生js实现游戏按钮

LeoHsiun / 3384人阅读

摘要:游戏按钮原生实现游戏的开始暂停结束实现使用实现实现步骤获取元素开始事件停止事件暂停事件定时器效果演示代码按钮动画样式输入游戏总时长分钟倒计时秒开始暂停结束有加入一丢丢的动画代码获取元素总时长剩余时长点开始按钮时间戳

游戏按钮

原生js实现游戏的‘开始’‘暂停’‘结束’

实现:

使用setInterval实现

js实现步骤:

获取元素

开始事件

停止事件

暂停事件

定时器

效果演示:

html代码

</>复制代码

  1. 按钮
  2. 分钟
  3. 倒计时:

有加入一丢丢c3的动画

js代码

</>复制代码

  1. window.onload = function(){
  2. // 1.获取元素
  3. var endTimeStr = document.getElementsByClassName("endTime")[0];
  4. var timeVal = document.getElementsByTagName("input")[0];
  5. var startBtn = document.getElementsByClassName("start")[0];
  6. var pauseBtn = document.getElementsByClassName("pause")[0];
  7. var stopBtn = document.getElementsByClassName("stop")[0];
  8. var totalTime, //总时长
  9. showTime,//剩余时长
  10. startTime, //点开始按钮时间戳
  11. nowTime,//定时器开启的时间戳
  12. timer;
  13. var timeType = 1; //1结束后开始 2暂停后开始
  14. // 2.开始事件
  15. startBtn.onclick = function(){
  16. if(timer) clearInterval(timer);
  17. if(timeType==1)totalTime = timeVal.value*60; //初始化总时长
  18. startTime = new Date(); //点击按钮开始时间
  19. startBtn.disabled = true;
  20. start();
  21. }
  22. // 3.停止事件
  23. stopBtn.onclick = function(){
  24. clearInterval(timer)
  25. timeType = 1;
  26. showTime = timeVal.value*60; //剩余时长
  27. endTimeStr.innerHTML = showTime;
  28. startBtn.disabled = false;
  29. }
  30. // 4.暂停事件
  31. pauseBtn.onclick = function(){
  32. clearInterval(timer)
  33. timeType = 2;
  34. startBtn.disabled = false;
  35. totalTime = showTime; //总时长==剩余时长
  36. }
  37. /*
  38. 定时器
  39. */
  40. function start(){
  41. nowTime = new Date();//定时器开始时间
  42. showTime = totalTime-parseInt((nowTime-startTime)/1000);
  43. endTimeStr.innerHTML = showTime;
  44. timer = setInterval(function(){
  45. showTime--;
  46. endTimeStr.innerHTML = showTime;
  47. if(showTime<1){
  48. clearInterval(timer)
  49. alert("游戏结束");
  50. }
  51. },100);
  52. }
  53. }

代码复制可直接查看效果

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/104457.html

相关文章

  • 前端每日实战:163# 视频演示如何用原生 JS 创作一个多选一场景的交互游戏(内含 3 个视频)

    摘要:本项目将设计一个多选一的交互场景,用进行页面布局用制作动画效果用原生编写程序逻辑。中包含个展示头像的和个标明当前被选中头像的。 showImg(https://segmentfault.com/img/bVbknOW?w=400&h=302); 效果预览 按下右侧的点击预览按钮可以在当前页面预览,点击链接可以全屏预览。 https://codepen.io/comehope/pen/L...

    pakolagij 评论0 收藏0
  • 前端每日实战:163# 视频演示如何用原生 JS 创作一个多选一场景的交互游戏(内含 3 个视频)

    摘要:本项目将设计一个多选一的交互场景,用进行页面布局用制作动画效果用原生编写程序逻辑。中包含个展示头像的和个标明当前被选中头像的。 showImg(https://segmentfault.com/img/bVbknOW?w=400&h=302); 效果预览 按下右侧的点击预览按钮可以在当前页面预览,点击链接可以全屏预览。 https://codepen.io/comehope/pen/L...

    antz 评论0 收藏0
  • 前端每日实战:163# 视频演示如何用原生 JS 创作一个多选一场景的交互游戏(内含 3 个视频)

    摘要:本项目将设计一个多选一的交互场景,用进行页面布局用制作动画效果用原生编写程序逻辑。中包含个展示头像的和个标明当前被选中头像的。 showImg(https://segmentfault.com/img/bVbknOW?w=400&h=302); 效果预览 按下右侧的点击预览按钮可以在当前页面预览,点击链接可以全屏预览。 https://codepen.io/comehope/pen/L...

    The question 评论0 收藏0
  • 菜鸟| 微信小游戏好友排行榜教程

    摘要:今天我们分享的菜鸟文档将介绍微信小游戏好友排行榜的制作过程,包括创建项目并发布微信开发者平台添加小游戏打开开放域功能主域和开放域通讯,以及与原生的布局。 写在前面:随着越来越多的新人开始接触白鹭引擎,创作属于自己的游戏。考虑到初学者会遇到一些实际操作问题,我们近期整理推出菜鸟系列技术文档,以便更好的让这些开发者们快速上手,Egret大神们可以自动忽略此类内容。 今天我们分享的菜鸟文档将...

    libxd 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<