Heim >Web-Frontend >js-Tutorial >JavaScript schreibt einen Timer

JavaScript schreibt einen Timer

高洛峰
高洛峰Original
2016-11-25 09:30:521203Durchsuche

Ich bin neu in JavaScript und habe einen Timer in JavaScript geschrieben.

Designidee:

1. Verwenden Sie das Date()-Objekt, um kontinuierlich Zeitpunkte zu erhalten.

2. Subtrahieren Sie dann die Millisekunden der beiden Zeitpunkte Differenz;

3. Akkumulieren Sie die Zeitdifferenz, damit das Timing genau sein kann.

ps:

Ich habe diese Methode im Internet nicht gesehen. Die Verzögerung und die Zeitsteuerung der Programmiersprache sind relativ groß >Also verwenden wir die Systemzeitsubtraktionsmethode, um die Genauigkeit zu steuern, und verwenden dieses Beispiel, um dreistellige Millisekundenzahlen anzuzeigen, um die Genauigkeit zu überprüfen. Die Einstellung beträgt 100 Millisekunden, und Js selbst weist Fehler auf Programmungenauigkeiten können vermieden werden.

Dieses Beispiel dient dem gegenseitigen Austausch und wir sind gespannt auf Ideen und Vorschläge der Leser.

< /title><br> <script type="text/javascript"><br> var tFlag = 0;<br> var tPass = 0;<br> function timer(id) {<br> if (tFlag ! = 0) {<br> var tNew = new Date().getTime();<br> tPass = tPass + (tNew - tFlag);<br> tFlag = tNew;<br><br> } else {<br> tFlag = new Date().getTime();<br> }<br> setTimeout("timer('" + id + "')", 100);<br> var ml = tPass % 1000;<br> var sc = Math.floor((tPass / 1000) % 60);<br> var mi = Math.floor((tPass / 1000 / 60) % 60);<br> var hr = Math.floor((tPass / 1000 / 60 / 60) % 24);<br> var dy = Math.floor(tPass / 1000 / 60 / 60 / 24);<br> var info = dy + „day“ + hr + „hour“ + mi + „Minuten“ + sc + „Sekunden“ + ml + „Millisekunden“;<br> document.getElementById(id).innerHTML = info;<br> }<br> </script><br> </head> ;<br/> <body><br> <button type="button" onclick="timer('ptime')"><br>Zeitmessung starten<br> </button><br> <S id="ptime"></p><br> </body><br></html><br><br><br><br><br></p></div><div class="nphpQianMsg"><div class="clear"></div></div><div class="nphpQianSheng"><span>Stellungnahme:</span><div>Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn</div></div></div><div class="nphpSytBox"><span>Vorheriger Artikel:<a class="dBlack" title="JavaScript ändert Seitenelemente dynamisch" href="https://m.php.cn/de/faq/340794.html">JavaScript ändert Seitenelemente dynamisch</a></span><span>Nächster Artikel:<a class="dBlack" title="JavaScript ändert Seitenelemente dynamisch" href="https://m.php.cn/de/faq/340798.html">JavaScript ändert Seitenelemente dynamisch</a></span></div><div class="nphpSytBox2"><div class="nphpZbktTitle"><h2>In Verbindung stehende Artikel</h2><em><a href="https://m.php.cn/de/article.html" class="bBlack"><i>Mehr sehen</i><b></b></a></em><div class="clear"></div></div><ins class="adsbygoogle" style="display:block" data-ad-format="fluid" data-ad-layout-key="-6t+ed+2i-1n-4w" data-ad-client="ca-pub-5902227090019525" data-ad-slot="8966999616"></ins><script> (adsbygoogle = window.adsbygoogle || []).push({}); </script><ul class="nphpXgwzList"><li><b></b><a href="https://m.php.cn/de/faq/1609.html" title="Eine eingehende Analyse der Bootstrap-Listengruppenkomponente" class="aBlack">Eine eingehende Analyse der Bootstrap-Listengruppenkomponente</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/de/faq/1640.html" title="Detaillierte Erläuterung des JavaScript-Funktions-Curryings" class="aBlack">Detaillierte Erläuterung des JavaScript-Funktions-Curryings</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/de/faq/1949.html" title="Vollständiges Beispiel für die Generierung von JS-Passwörtern und die Erkennung der Stärke (mit Download des Demo-Quellcodes)" class="aBlack">Vollständiges Beispiel für die Generierung von JS-Passwörtern und die Erkennung der Stärke (mit Download des Demo-Quellcodes)</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/de/faq/2248.html" title="Angularjs integriert WeChat UI (weui)" class="aBlack">Angularjs integriert WeChat UI (weui)</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/de/faq/2351.html" title="Wie man mit JavaScript schnell zwischen traditionellem Chinesisch und vereinfachtem Chinesisch wechselt und wie Websites den Wechsel zwischen vereinfachtem und traditionellem Chinesisch unterstützen – Javascript-Kenntnisse" class="aBlack">Wie man mit JavaScript schnell zwischen traditionellem Chinesisch und vereinfachtem Chinesisch wechselt und wie Websites den Wechsel zwischen vereinfachtem und traditionellem Chinesisch unterstützen – Javascript-Kenntnisse</a><div class="clear"></div></li></ul></div></div><ins class="adsbygoogle" style="display:block" data-ad-format="autorelaxed" data-ad-client="ca-pub-5902227090019525" data-ad-slot="5027754603"></ins><script> (adsbygoogle = window.adsbygoogle || []).push({}); </script><footer><div class="footer"><div class="footertop"><img src="/static/imghwm/logo.png" alt=""><p>Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!</p></div><div class="footermid"><a href="https://m.php.cn/de/about/us.html">Über uns</a><a href="https://m.php.cn/de/about/disclaimer.html">Haftungsausschluss</a><a href="https://m.php.cn/de/update/article_0_1.html">Sitemap</a></div><div class="footerbottom"><p> © php.cn All rights reserved </p></div></div></footer><script>isLogin = 0;</script><script type="text/javascript" src="/static/layui/layui.js"></script><script type="text/javascript" src="/static/js/global.js?4.9.47"></script></div><script src="https://vdse.bdstatic.com//search-video.v1.min.js"></script><link rel='stylesheet' id='_main-css' href='/static/css/viewer.min.css' type='text/css' media='all'/><script type='text/javascript' src='/static/js/viewer.min.js?1'></script><script type='text/javascript' src='/static/js/jquery-viewer.min.js'></script><script>jQuery.fn.wait = function (func, times, interval) { var _times = times || -1, //100次 _interval = interval || 20, //20毫秒每次 _self = this, _selector = this.selector, //选择器 _iIntervalID; //定时器id if( this.length ){ //如果已经获取到了,就直接执行函数 func && func.call(this); } else { _iIntervalID = setInterval(function() { if(!_times) { //是0就退出 clearInterval(_iIntervalID); } _times <= 0 || _times--; //如果是正数就 -- _self = $(_selector); //再次选择 if( _self.length ) { //判断是否取到 func && func.call(_self); clearInterval(_iIntervalID); } }, _interval); } return this; } $("table.syntaxhighlighter").wait(function() { $('table.syntaxhighlighter').append("<p class='cnblogs_code_footer'><span class='cnblogs_code_footer_icon'></span></p>"); }); $(document).on("click", ".cnblogs_code_footer",function(){ $(this).parents('table.syntaxhighlighter').css('display','inline-table');$(this).hide(); }); $('.nphpQianCont').viewer({navbar:true,title:false,toolbar:false,movable:false,viewed:function(){$('img').click(function(){$('.viewer-close').trigger('click');});}}); </script></body></html>