这里有新鲜出炉的 Javascript 教程,程序狗速度看过来!
Javascript 是一种由 Netscape 的 LiveScript 发展而来的原型化继承的基于对象的动态类型的区分大小写的客户端脚本语言,主要目的是为了解决服务器端语言,比如 Perl,遗留的速度问题,为客户提供更流畅的浏览效果。
这篇文章主要为大家详细介绍了 javascript 实现计时器的简单方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
计时器, 在生活当中也是用得频繁的功能, 比如锻炼身体, 跑步比赛等等相关的活动. 我们用 Javascript 来完成一个计时器.
计时器, 主要就是对时间的一个逻辑处理, 比如 60 秒等于 1 分钟, 60 分钟等于一个小时, 我们这里只做到小时的处理. 就这么一个简单的逻辑, 然后动态的显示在一个 Input 里面.
那现在我们来完成这个界面
- <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 程序设计有所帮助。
来源: http://www.phperz.com/article/17/0409/267055.html