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 相关文章推荐
javascript数字数组去重复项的实现代码
Dec 30 Javascript
简单的JS时钟实例讲解
Jan 13 Javascript
简单实现js页面切换功能
Jan 10 Javascript
Javascript调试之console对象——你不知道的一些小技巧
Jul 10 Javascript
easyui-datagrid开发实践(总结)
Aug 02 Javascript
使用socket.io实现简单聊天室案例
Jan 02 Javascript
vue如何通过id从列表页跳转到对应的详情页
May 01 Javascript
Vue中对拿到的数据进行A-Z排序的实例
Sep 25 Javascript
Vue分页器实现原理详解
Jun 28 Javascript
Flutter实现仿微信底部菜单栏功能
Sep 18 Javascript
JavaScript实现动态生成表格
Aug 02 Javascript
JS前端轻量fabric.js系列之画布初始化
Aug 05 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
win7下memCache的安装过程(具体操作步骤)
2013/06/28 PHP
php中print(),print_r(),echo()的区别详解
2014/12/01 PHP
php实现两表合并成新表并且有序排列的方法
2014/12/05 PHP
PHP CURL或file_get_contents获取网页标题的代码及两者效率的稳定性问题
2015/11/30 PHP
PHP+Ajax+JS实现多图上传
2016/05/07 PHP
php解析非标准json、非规范json的方式实例
2020/12/10 PHP
javascript动态添加表格数据行(ASP后台数据库保存例子)
2010/05/08 Javascript
《JavaScript高级程序设计》阅读笔记(二) ECMAScript中的原始类型
2012/02/27 Javascript
cookie的复制与使用记住用户名实现代码
2013/11/04 Javascript
详解jQuery向动态生成的内容添加事件响应jQuery live()方法
2015/11/02 Javascript
通过javascript进行UTF-8编码的实现方法
2016/06/27 Javascript
JS判断输入的字符串是否是数字的方法(正则表达式)
2016/11/29 Javascript
解决浏览器会自动填充密码的问题
2017/04/28 Javascript
js+html5实现页面可刷新的倒计时效果
2017/07/15 Javascript
Kindeditor单独调用单图上传增加预览功能的实例
2017/07/31 Javascript
深入理解ES6的迭代器与生成器
2017/08/19 Javascript
使用node.js对音视频文件加密的实例代码
2017/08/30 Javascript
JS+HTML5 Canvas实现简单的写字板功能示例
2018/08/30 Javascript
vue.draggable实现表格拖拽排序效果
2018/12/01 Javascript
详解vue的双向绑定原理及实现
2019/05/05 Javascript
javascript获取元素的计算样式
2019/05/24 Javascript
Vue 权限控制的两种方法(路由验证)
2019/08/16 Javascript
layer.open 子页面弹出层向父页面传输数据的例子
2019/09/26 Javascript
Vue结合路由配置递归实现菜单栏功能
2020/06/16 Javascript
[03:01]完美世界DOTA2联赛PWL S2 集锦第二期
2020/12/03 DOTA
Flask框架学习笔记(一)安装篇(windows安装与centos安装)
2014/06/25 Python
如何在Django中使用聚合的实现示例
2020/03/23 Python
python中读入二维csv格式的表格方法详解(以元组/列表形式表示)
2020/04/24 Python
python能做哪些生活有趣的事情
2020/09/09 Python
使用Python获取爱奇艺电视剧弹幕数据的示例代码
2021/01/12 Python
德国最大的拼图在线商店:Puzzle.de
2016/12/17 全球购物
美国购买体育、音乐会和剧院门票网站:SelectATicket
2019/09/08 全球购物
小学毕业感言300字
2014/02/19 职场文书
小班下学期评语
2014/05/04 职场文书
工程部文员岗位职责
2015/02/04 职场文书
在职证明格式样本
2015/06/15 职场文书