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 event 事件解析
Jan 31 Javascript
快速解决jQuery与其他库冲突的方法介绍
Jan 02 Javascript
jquery数组过滤筛选方法grep()简介
Jun 06 Javascript
javascript实现表格增删改操作实例详解
May 15 Javascript
jQuery实现百叶窗焦点图动画效果代码分享(附源码下载)
Mar 14 Javascript
利用Query+bootstrap和js两种方式实现日期选择器
Jan 10 Javascript
javascript 操作cookies详解及实例
Feb 22 Javascript
搭建element-ui的Vue前端工程操作实例
Feb 23 Javascript
vue.js使用v-pre与v-html输出HTML操作示例
Jul 07 Javascript
解决在vue项目中webpack打包后字体不生效的问题
Sep 01 Javascript
详解Vue中的scoped及穿透方法
Apr 18 Javascript
微信小程序实现消息框弹出动画
Apr 18 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代码
2006/12/06 PHP
PHP和Mysqlweb应用开发核心技术 第1部分 Php基础-1 开始了解php
2011/07/03 PHP
PHP 前加at符合@的作用解析
2015/07/31 PHP
PHP 数组遍历foreach语法结构及实例
2016/06/13 PHP
PHP扩展类型及安装方式解析
2020/04/27 PHP
用javascript实现兼容IE7的类库 IE7_0_9.zip提供下载
2007/08/08 Javascript
jquery调用asp.net 页面后台的实现代码
2011/04/27 Javascript
JS继承--原型链继承和类式继承
2013/04/08 Javascript
jQuery prev ~ siblings选择器使用介绍
2013/08/09 Javascript
禁止选中文字兼容IE、Chrome、FF等
2013/09/04 Javascript
jquery checkbox实现单选小例
2013/11/27 Javascript
jquery、js调用iframe父窗口与子窗口元素的方法整理
2014/07/31 Javascript
完美兼容多浏览器的js判断图片路径代码汇总
2015/04/17 Javascript
javascript三种代码注释方法
2016/06/02 Javascript
javascript this详细介绍
2016/09/19 Javascript
Vue组件化通讯的实例代码
2017/06/23 Javascript
详解EasyUi控件中的Datagrid
2017/08/23 Javascript
原生js实现淘宝放大镜效果
2020/10/28 Javascript
Node.js JSON模块用法实例分析
2019/01/04 Javascript
Python中subprocess的简单使用示例
2015/07/28 Python
Python利用递归和walk()遍历目录文件的方法示例
2017/07/14 Python
解决pandas 作图无法显示中文的问题
2018/05/24 Python
Python Dataframe 指定多列去重、求差集的方法
2018/07/10 Python
python 自动轨迹绘制的实例代码
2019/07/05 Python
python将字母转化为数字实例方法
2019/10/04 Python
python 爬取马蜂窝景点翻页文字评论的实现
2020/01/20 Python
python输出pdf文档的实例
2020/02/13 Python
python实现贪吃蛇游戏源码
2020/03/21 Python
HTML5拍照和摄像机功能实战详解
2019/01/24 HTML / CSS
大学生农村教师实习自我鉴定
2013/09/21 职场文书
中学生期中自我鉴定
2014/04/20 职场文书
创建文明城市倡议书
2015/04/28 职场文书
员工表扬信怎么写
2015/05/05 职场文书
教师节随笔
2015/08/15 职场文书
让人感觉高大上的讲话稿怎么写?
2019/07/08 职场文书
react 路由Link配置详解
2021/11/11 Javascript