快活林资源网 Design By www.csstdc.com
js实现类似iphone的秒表,添加平均数功能
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="initial-scale=1, maximum-scale=1, user-scalable=no, width=device-width"> <title>stop watch</title> <!--by 0o晓月メ http://www.cnblogs.com/final-elysion/p/6066358.html --> <script type="text/javascript"> //起始计时时间 var totalStartTime = null; var countStartTime = null; //暂停时的时间 var stopCountTime = 0; var stopTotalTime = 0; //保存的计次时间列表 var countList = []; //循环指针 var changeTime = null; var addnewValue = false; var begin = false; //label & 缓存已经使用的时间 var countTime = null; var totalTime = null; beginChange = function(){ //设置标志位进行控制,避免多线程造成的变量问题 begin = true; changeTime = setInterval(changeStopWatch,10); document.getElementById('begin').disabled = true; document.getElementById('stop').disabled = false; document.getElementById('commit').disabled = false; document.getElementById('reset').disabled = true; } /** * 计时器核心方法 */ changeStopWatch = function(){ if(begin){ totalStartTime = new Date(); countStartTime = totalStartTime; begin = false; }else if(addnewValue){ //重设新的起始时间 暂停的时间点 countStartTime = new Date(); stopCountTime = 0; addnewValue = false; } var now = new Date(); var tempTotal = (now.getTime() - totalStartTime.getTime())/1000 + stopTotalTime; var tempCount = (now.getTime() - countStartTime.getTime())/1000 + stopCountTime; tempTotal = Math.floor(tempTotal * 100) / 100; tempCount = Math.floor(tempCount * 100) / 100; //多线程问题有时候会出现这情况 if(tempTotal < 0 || tempCount < 0){ console.log('bug') return ; } setTotalTime(tempTotal); setCountTime(tempCount); } stopChange = function(){ clearInterval(changeTime); stopCountTime = countTime; stopTotalTime = totalTime; document.getElementById('begin').disabled = false; document.getElementById('stop').disabled = true; document.getElementById('commit').disabled = true; document.getElementById('reset').disabled = false; } addNewValue = function (){ //缓存添加的时间 var newValue = countTime; countList.push(newValue); //设置标志位进行控制,避免多线程造成的变量问题 addnewValue = true; //刷新页面 setNewValue(newValue); changeAverage(); } changeAverage = function(){ var total = 0, i = 0; for(;i<countList.length; i++){ total = total +countList[i]; } var result = Math.floor(total/i * 100) / 100; document.getElementById('average').innerText = secondToTime(result); document.getElementById('average-second').innerText = result; } resetStopWatch = function(){ totalStartTime = 0; countStartTime = 0; stopCountTime = 0; stopTotalTime = 0; countList = []; changeTime = null; addnewValue = false; begin = false; setCountTime(0); setTotalTime(0); document.getElementById('result').innerHTML = ""; document.getElementById('average').innerText = "00:00:00.00"; document.getElementById('result-second').innerHTML = ""; document.getElementById('average-second').innerText = "0"; } function secondToTime(time) { var result = ""; if (null != time && "" != time && time > 0) { //hour if (time >= 60 * 60) { result = parseInt(time / 3600); if(result< 10){ result = "0" + result + ":"; }else{ result = result + ":" } }else{ result = "00:" } //min if (time >= 60) { var tempMin = parseInt((time - parseInt(time / 3600) * 3600 )/ 60) ; if(tempMin < 10){ tempMin = "0" + tempMin + ":"; }else{ tempMin = tempMin + ":" } result = result + tempMin; }else{ result = result + "00:"; } //second var timeStr = time + ""; var tempSecond = parseInt(time%60); if(tempSecond < 10){ tempSecond = "0" + tempSecond; } if(timeStr.indexOf(".") >= 0){ tempSecond = tempSecond + timeStr.substring(timeStr.indexOf("."),timeStr.length); } result = result + tempSecond; }else{ result = "00:00:00.00"; } return result; } getCountTime = function(){ return document.getElementById('count-Time'); } setCountTime = function(value){ countTime = value; document.getElementById('count-second-Time').innerText = value; document.getElementById('count-Time').innerText = secondToTime(value); } getTotalTime = function(){ return document.getElementById('total-Time'); } setTotalTime = function(value){ totalTime = value; document.getElementById('total-Time').innerText = secondToTime(value); document.getElementById('total-second-Time').innerText = value; } setNewValue = function(value){ var newNode = document.createElement("div"); newNode.innerHTML = secondToTime(value); var oldNode = document.getElementById('result'); oldNode.appendChild(newNode); var newNode2 = document.createElement("div"); newNode2.innerHTML = value; var oldNode2 = document.getElementById('result-second'); oldNode2.appendChild(newNode2); } </script> </head> <body > <div style="width: 430px;border-width: 2px;border-style: solid;padding: 10px 10px 10px 10px;"> <input type="button" id ="begin" value="启动" onclick="beginChange()"/> <input type="button" id = "stop" value="停止" disabled="true" onclick="stopChange()"/> <input type="button" id = "commit" value="计次" disabled="true" onclick="addNewValue()"/> <input type="button" id = "reset" value="重置" disabled="true" onclick="resetStopWatch()"/> <br /> <div style="width:200px;margin-top:10px;" > <div style="padding-top:20px;">当前次数计时</div> <div id="count-Time" > 00:00:00.00 </div> <div style="padding-top:20px;">总时间计时</div> <div id="total-Time" > 00:00:00.00 </div> <div style="padding-top:20px;"> <div>平均值</div> <div id ="average" >00:00:00.00</div> </div> </div> <div style="width: 200px;position: absolute;left: 300px;top: 50px;" > <div style="padding-top:20px;">当前次数计时(秒)</div> <div id="count-second-Time"> 0 </div> <div style="padding-top:20px;">总时间计时(秒)</div> <div id="total-second-Time"> 0 </div> <div style="padding-top:20px;"> <div>平均值(秒)</div> <div id ="average-second" >0</div> </div> </div> </div> <div style="width:200px;margin-top:21px;"> 添加的次数列表 <div id="result" > </div> </div> <div style="width: 200px;position: absolute;left: 300px;top:253px;"> 添加的次数列表(秒) <div id="result-second" > </div> </div> </body> </html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
快活林资源网 Design By www.csstdc.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
快活林资源网 Design By www.csstdc.com
暂无评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
2025年01月14日
2025年01月14日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]