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 相关文章推荐
清华大学出版的事半功倍系列 javascript全部源代码
May 04 Javascript
JS 非图片动态loading效果实现代码
Apr 09 Javascript
js获取日期:昨天今天和明天、后天
Jun 11 Javascript
node.js操作mongoDB数据库示例分享
Nov 26 Javascript
JavaScript实现梯形乘法表的方法
Apr 25 Javascript
jQuery获取attr()与prop()属性值的方法及区别介绍
Jul 06 Javascript
用JS写的一个Ajax库(实例代码)
Aug 06 Javascript
原生node.js案例--前后台交互
Feb 20 Javascript
Node.js进阶之核心模块https入门
May 23 Javascript
React性能优化系列之减少props改变的实现方法
Jan 17 Javascript
vue实现todolist基本功能以及数据存储功能实例详解
Apr 11 Javascript
vue实现登录页面的验证码以及验证过程解析(面向新手)
Aug 02 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
用PHP和ACCESS写聊天室(三)
2006/10/09 PHP
php知道与问问的采集插件代码
2010/10/12 PHP
php实现utf-8转unicode函数分享
2015/01/06 PHP
Yii2.0高级框架数据库增删改查的一些操作
2015/11/16 PHP
CI操作cookie的方法分析(基于helper类库)
2016/03/28 PHP
Javascript之文件操作
2007/03/07 Javascript
推荐自用 Javascript 缩图函数 (onDOMLoaded)……
2007/10/23 Javascript
JavaScript表单常用验证集合
2008/01/16 Javascript
让mayfish支持mysqli数据库驱动的实现方法
2010/05/22 Javascript
JS Pro-深入面向对象的程序设计之继承的详解
2013/05/07 Javascript
javascript实现省市区三级联动下拉框菜单
2015/11/17 Javascript
NodeJS连接MongoDB数据库时报错的快速解决方法
2016/05/13 NodeJs
vue + socket.io实现一个简易聊天室示例代码
2017/03/06 Javascript
详解Angular5 路由传参的3种方法
2018/04/28 Javascript
NodeJS使用Range请求实现下载功能的方法示例
2018/10/12 NodeJs
vue 集成jTopo 处理方法
2019/08/07 Javascript
详解Vue中的watch和computed
2020/11/09 Javascript
手把手教你如何编译打包video.js
2020/12/09 Javascript
python逐行读取文件内容的三种方法
2014/01/20 Python
Python的Django框架中自定义模版标签的示例
2015/07/20 Python
详解python字节码
2018/02/07 Python
基于Python List的赋值方法
2018/06/23 Python
Python3.4解释器用法简单示例
2019/03/22 Python
Python数据类型之List列表实例详解
2019/05/08 Python
Python实现Mysql数据统计及numpy统计函数
2019/07/15 Python
Python API len函数操作过程解析
2020/03/05 Python
Python 列表中的修改、添加和删除元素的实现
2020/06/11 Python
基于python实现判断字符串是否数字算法
2020/07/10 Python
如何利用Python 进行边缘检测
2020/10/14 Python
Python基于mediainfo批量重命名图片文件
2020/12/29 Python
芭比波朗加拿大官方网站:Bobbi Brown Cosmetics CA
2020/11/05 全球购物
分厂厂长岗位职责
2013/12/29 职场文书
中学生社会实践活动总结
2014/07/03 职场文书
2014年第四季度入党积极分子思想汇报(十八届四中全会)
2014/11/03 职场文书
小学语文的各类谚语(70首)
2019/08/15 职场文书
go web 预防跨站脚本的实现方式
2021/06/11 Golang