javascript实现计时器的简单方法


Posted in Javascript onFebruary 21, 2016

计时器, 在生活当中也是用得频繁的功能, 比如锻炼身体, 跑步比赛等等相关的活动. 我们用Javascript来完成一个计时器.

计时器, 主要就是对时间的一个逻辑处理, 比如60秒等于1分钟, 60分钟等于一个小时, 我们这里只做到小时的处理. 就这么一个简单的逻辑, 然后动态的显示在一个Input里面.

javascript实现计时器的简单方法

那现在我们来完成这个界面

<label>计时:</label> 
<input type="text" name="" id="timer"/> 
<button onclick="pause(this)" id="pause" state="on">暂停</button>
<button onclick="restart()">重新开始</button>

给标签元素一个ID是为了获取其中的标签, 然后加入了两个点击事件, 计数器的暂停, 和重新开始事件.

首先我们来完成开始计时的处理, 开始计时主要还是是用了setInterval的方法, 其中每隔1秒执行一次方法, 这样我们就可以对时间做处理, 就像开头所说60秒等于1分钟..., 所以这里就需要用判断来处理, 最后就将其中的得到的秒,分,时显示到输入框里.

var ele_timer = document.getElementById("timer");
var n_sec = 0; //秒
var n_min = 0; //分
var n_hour = 0; //时

//60秒 === 1分
//60分 === 1小时
function timer() {
 return setInterval(function () {

 var str_sec = n_sec;
 var str_min = n_min;
 var str_hour = n_hour;
 if ( n_sec < 10) {
  str_sec = "0" + n_sec;
 }
 if ( n_min < 10 ) {
  str_min = "0" + n_min;
 }

 if ( n_hour < 10 ) {
  str_hour = "0" + n_hour;
 }

 var time = str_hour + ":" + str_min + ":" + str_sec;
 ele_timer.value = time;
 n_sec++;
 if (n_sec > 59){
  n_sec = 0;
  n_min++;
 }
 if (n_min > 59) {
  n_sec = 0;
  n_hour++;
 }


 }, 1000);
}

var n_timer = timer();

我们用timer方法包装setInterval方法是为了,后面暂停和重新开始做处理.
用户点击了暂停, 计时器就停止计时, 用户继续点击这个按钮, 计时器继续计时. 所以这里有一个状态需要控制,这个状态我们给这个按钮一个属性.

//暂停和继续
function pause(self) {
 var state = self.getAttribute("state");
 if (state === "on") {
  clearInterval(n_timer);
  self.textContent = "继续";
  self.setAttribute("state", "off");
 } else {
  n_timer = timer();
  self.textContent = "暂停";
  self.setAttribute("state", "on");
 }
}

最后我们来看一下重新开始, 重新开始事件就更加简单了. 将计数器清0, 然后改变暂停按钮初始状态.

function restart() {
 clearInterval(n_timer);
 n_sec = 0;
 n_min = 0;
 n_hour = 0;
 n_timer = timer();

 var ele_pause = document.getElementById("pause");
 ele_pause.textContent = "暂停";
 ele_pause.setAttribute("state", "on");
}

这样就完成了计时的功能.效果如下

javascript实现计时器的简单方法

希望本文所述对大家学习javascript程序设计有所帮助。

Javascript 相关文章推荐
2010年最佳jQuery插件整理
Dec 06 Javascript
如何确保JavaScript的执行顺序 之实战篇
Mar 03 Javascript
[JSF]使用DataModel处理表行事件的实例代码
Aug 05 Javascript
javascript实现锁定网页、密码解锁效果(类似系统屏幕保护效果)
Aug 15 Javascript
简单谈谈JavaScript的同步与异步
Dec 31 Javascript
jQuery实现指定区域外单击关闭指定层的方法【经典】
Jun 22 Javascript
js中通过getElementsByName访问name集合对象的方法
Oct 31 Javascript
js代码延迟一定时间后执行一个函数的实例
Feb 15 Javascript
JavaScript操作文件_动力节点Java学院整理
Jun 30 Javascript
tween.js缓动补间动画算法示例
Feb 13 Javascript
微信小程序表单验证WxValidate的使用
Nov 27 Javascript
Vue双向绑定实现原理与方法详解
May 07 Javascript
JS中Eval解析JSON字符串的一个小问题
Feb 21 #Javascript
浏览器检测JS代码(兼容目前各大主流浏览器)
Feb 21 #Javascript
gameboy网页闯关游戏(riddle webgame)--仿微信聊天的前端页面设计和难点
Feb 21 #Javascript
全面详细的jQuery常见开发技巧手册
Feb 21 #Javascript
完善的jquery处理机制
Feb 21 #Javascript
jquery对象和DOM对象的任意相互转换
Feb 21 #Javascript
jQuery实现div拖拽效果实例分析
Feb 20 #Javascript
You might like
phpmyadmin提示The mbstring extension is missing的解决方法
2014/12/17 PHP
使用php的HTTP请求的库Requests实现美女图片墙
2015/02/22 PHP
PHP连接MySQL数据的操作要点
2015/03/20 PHP
浅析PHP中的闭包和匿名函数
2017/12/25 PHP
JS启动应用程序的一个简单例子
2008/05/11 Javascript
EasySlider 基于jQuery功能强大简单易用的滑动门插件
2010/06/11 Javascript
javascript结合html5 canvas实现(可调画笔颜色/粗细/橡皮)的涂鸦板
2013/04/27 Javascript
js获得网页背景色和字体色的方法
2014/03/21 Javascript
Bootstrap Paginator分页插件使用方法详解
2016/05/30 Javascript
javascript验证内容为数字以及长度为10的简单实例
2016/08/20 Javascript
jQuery实现选项卡功能(两种方法)
2017/03/08 Javascript
AngularJS实现动态添加Option的方法
2017/05/17 Javascript
JS 组件系列之Bootstrap Table 冻结列功能IE浏览器兼容性问题解决方案
2017/06/30 Javascript
AugularJS从入门到实践(必看篇)
2017/07/10 Javascript
AngularJS实现的select二级联动下拉菜单功能示例
2017/10/25 Javascript
旺旺在线客服代码 旺旺客服代码生成器
2018/01/09 Javascript
详解如何模拟实现node中的Events模块(通俗易懂版)
2019/04/15 Javascript
vue props 一次传多个值实例
2020/07/22 Javascript
[01:43]3.19DOTA2发布会 三代刀塔人第三代
2014/03/25 DOTA
Python下Fabric的简单部署方法
2015/07/14 Python
Python使用自带的ConfigParser模块读写ini配置文件
2016/06/26 Python
python使用pdfminer解析pdf文件的方法示例
2018/12/20 Python
python消费kafka数据批量插入到es的方法
2018/12/27 Python
Django实现发送邮件功能
2019/07/18 Python
Flask教程之重定向与错误处理实例分析
2019/08/01 Python
Python 读取 YUV(NV12) 视频文件实例
2019/12/09 Python
Paradigit比利时电脑卖场:购买笔记本、电脑、平板和外围设备
2016/11/28 全球购物
Asics日本官网:鬼冢八喜郎创立的跑鞋运动品牌
2017/10/18 全球购物
护理学毕业生自荐信
2013/10/02 职场文书
本科毕业生的求职信范文
2013/11/20 职场文书
九年级政治教学反思
2014/02/06 职场文书
狮子林导游词
2015/02/03 职场文书
演讲比赛主持词
2015/06/29 职场文书
100句拼搏进取的名言警句,值得一读!
2019/10/07 职场文书
你离财务总监还有多远?速览CFO的岗位职责
2019/11/18 职场文书
postgresql中如何执行sql文件
2023/05/08 PostgreSQL