js实现简单的秒表


Posted in Javascript onJanuary 16, 2020

本文实例为大家分享了js实现简单的秒表具体代码,供大家参考,具体内容如下

描述:

实现一个简单的秒表,点击启动按钮时开始计时,随后启动按钮变为暂停,

点击暂停暂停计时,点击复位回到最初始状态。

效果:

js实现简单的秒表

代码:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Title</title>
 <style>
 #showTime
 {
  width: 300px;
  height: 60px;
  font-size: 60px;
  line-height: 60px;
 }
 </style>
</head>
<body>
 <div>
 <div id="showTime">00:00:00</div>
 <button id="startBn">启动</button>
 <button id="restBn">复位</button>
 </div>
<script>
 //——————
 var time,showTime,startBn,restBn,pauseDate;
 //布尔开关
 var bool=false;
 //暂停的累计时间
 var pauseTime=0;
 
 init();
 function init() {
 showTime=document.getElementById("showTime");
 startBn=document.getElementById("startBn");
 restBn=document.getElementById("restBn");
 startBn.addEventListener("click",clickHandler);//开始按钮 ~ 暂停按钮
 restBn.addEventListener("click",clickHandler);//复位按钮
 setInterval(animation,16);
 }
 
 //转化时间函数
 function animation() {
 if(!bool) return;
 //前时间减去上次开启时间减去暂停累计时间
 var times=new Date().getTime()-time-pauseTime;
 var minutes=Math.floor(times/60000);//毫秒转化为分钟
 var seconds=Math.floor((times-minutes*60000)/1000);//已知分钟 
 将time减去分钟 除去1000得出 秒
 var ms=Math.floor((times-minutes*60000-seconds*1000)/10);//
 showTime.innerHTML=
  (minutes<10 ? "0" +minutes : minutes)+":"
  +(seconds<10 ? "0"+seconds :seconds)+":"
 +(ms<10 ? "0"+ms : ms);
 }
 
 //点击时的事件
 function clickHandler(e) {
 e= e || window.event;
 if(this===startBn){
  bool=!bool;
  if(bool){
  this.innerHTML="暂停";
  //如果我们上一次暂停时间是空,表示没有暂停过,因此,直接返回0
  //如果上次的暂停时间是有值得,用当前毫秒数减去上次的毫秒数,这样就会得到暂停时间
  pauseTime+=(!pauseDate ? 0 : new Date().getTime()-pauseDate);
  if(time) return;
  time=new Date().getTime();
  return;//是为bool判断跳出
  }
 
  this.innerHTML="启动";
  pauseDate=new Date().getTime();
  return;//是为this是否等于startBn判断跳出
 }
 startBn.innerHTML="启动";
 pauseTime=0;
 pauseDate=null;
 bool=false;
 time=0;
 showTime.innerHTML="00:00:00";
 }
 
</script>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
关于文本框的一些限制控制总结~~
Apr 15 Javascript
防止浏览器记住用户名及密码的简单实用方法
Apr 22 Javascript
jQuery 中国省市两级联动选择附图
May 14 Javascript
javascript实现移动端上的触屏拖拽功能
Mar 04 Javascript
微信小程序 地图定位简单实例
Oct 14 Javascript
iscroll实现下拉刷新功能
Jul 18 Javascript
详解react-webpack2-热模块替换[HMR]
Aug 03 Javascript
vue实现验证码输入框组件
Dec 14 Javascript
利用Decorator如何控制Koa路由详解
Jun 26 Javascript
vue2.0移动端滑动事件vue-touch的实例代码
Nov 27 Javascript
微信小程序获取用户openid的实现
Dec 24 Javascript
extjs图形绘制之饼图实现方法分析
Mar 06 Javascript
JS 数组基本用法入门示例解析
Jan 16 #Javascript
js实现上下左右键盘控制div移动
Jan 16 #Javascript
vue-cli3 取消eslint校验代码的解决办法
Jan 16 #Javascript
jQuery实现数字华容道小游戏(实例代码)
Jan 16 #jQuery
js实现点击生成随机div
Jan 16 #Javascript
关于vue3.0中的this.$router.replace({ path: '/'})刷新无效果问题
Jan 16 #Javascript
JS实现可视化音频效果的实例代码
Jan 16 #Javascript
You might like
新浪微博API开发简介之用户授权(PHP基础篇)
2011/09/25 PHP
header跳转和include包含问题详解
2012/09/08 PHP
PHP数字前补0的自带函数sprintf 和number_format的用法(详解)
2017/02/06 PHP
Laravel5.5 数据库迁移:创建表与修改表示例
2019/10/23 PHP
php正则表达式使用方法整理集合
2020/01/31 PHP
用于自动添加Digg This!按钮的JavaScript
2006/12/23 Javascript
javascript的offset、client、scroll使用方法详解
2012/12/25 Javascript
js检测输入内容全为空格的方法
2014/05/03 Javascript
js利用prototype调用Array的slice方法示例
2014/06/09 Javascript
jQuery中replaceWith()方法用法实例
2014/12/25 Javascript
JavaScript使用指针操作实现约瑟夫问题实例
2015/04/07 Javascript
JQuery用户名校验的具体实现
2016/03/18 Javascript
JS实现图片延迟加载并淡入淡出效果的简单方法
2016/08/25 Javascript
微信小程序 数据访问实例详解
2016/10/08 Javascript
在DWR中实现直接获取一个JAVA类的返回值的两种方法
2016/12/25 Javascript
vue模板语法-插值详解
2017/03/06 Javascript
如何使用Bootstrap创建表单
2017/03/29 Javascript
Vue 框架之动态绑定 css 样式实例分析
2018/11/14 Javascript
Vue.js组件实现选项卡以及切换特效
2019/07/24 Javascript
python开发之文件操作用法实例
2015/11/13 Python
Python的for和break循环结构中使用else语句的技巧
2016/05/24 Python
Unicode和Python的中文处理
2017/03/19 Python
Python基础学习之常见的内建函数整理
2017/09/06 Python
python执行CMD指令,并获取返回的方法
2018/12/19 Python
PyQt5 界面显示无响应的实现
2020/03/26 Python
日本网路线上商品代购服务:转送JAPAN
2016/08/05 全球购物
Structs界面控制层技术
2013/10/11 面试题
工作中的自我评价如何写好
2013/10/28 职场文书
会计岗位职责
2013/11/08 职场文书
表彰先进的通报
2014/01/31 职场文书
三方协议书
2015/01/27 职场文书
2015年团队工作总结范文
2015/05/04 职场文书
2015年大班保育员工作总结
2015/05/18 职场文书
2015年乡镇卫生院妇幼保健工作总结
2015/05/19 职场文书
简述Java中throw-throws异常抛出
2021/08/07 Java/Android
CSS使用SVG实现动态分布的圆环发散路径动画
2022/12/24 HTML / CSS