Home >Web Front-end >JS Tutorial >js chain delayed execution DOME_javascript technique

js chain delayed execution DOME_javascript technique

WBOY
WBOYOriginal
2016-05-16 17:57:411242browse

Execute in this form:

Copy the code The code is as follows:

d.wait(3000). run(function(m){ //Wait for 3 seconds
alert('Once upon a time there was a mountain');
}).wait(1000).run(function(m){ //Wait for 1 second
alert('There is a temple in the mountain');
}).wait(2000).run(function(m){ //Wait for 2 seconds
alert('There is an old monk in the temple to a young monk Tell a story');
}).wait(3000).run(function(m){ //Wait for 3 seconds
alert('The story is:');
}).goStart( ; 🎜>
The code is as follows:


Asynchronous execution</title> ; <U></head> <body> </a><script type="text/javascript"> </span>function Delay(){ </div>this.funList= []; <div class="codebody" id="code25698">this.index = 0; <br>this.re = null; <br>this.isloop = false; <br>}; <br>Delay.prototype = { <br>wait:function(m){ <br>if(this.funList[this.index] && typeof this.funList[this.index].fun != 'function'){ <br>m = this.funList[this.index].m; <br> } <br>this.funList[this.index] = {m:m,fun:null}; <br>return this; <br>}, <br>run:function(fun){ <br>if(typeof this.funList[this.index].fun != 'function'){ <br>this.funList[this.index].fun = fun; <br>this.index ; <br>}else{ <br>this .index ; <br>this.funList[this.index] = {'m':0,'fun':fun}; <br>} <br>this.start(); <br>return this; <br>}, <br>start:function(){ <br>var self = this; <br>if(this.re) return; <br>var setOutrun = function(funList,index){ <br>if(funList [index] == undefined){ <br>clearTimeout(self.re); <br>return false; <br>} <br>var m = funList[index].m, <br>fun = funList[index] .fun; <br>typeof fun == 'function' || (fun = function(){}); <br>self.re = setTimeout(function(){ <br>if(fun(index) === false)return false; <br>if(self.isloop){ <br>index = -1; <br>self.isloop = false; <br>} <br>setOutrun(funList, index); <br>} ,m); <br>} <br>setOutrun(this.funList,0); <br>}, <br>stop:function(){ <br>return clearTimeout(this.re); <br>}, <br>goStart:function(){ <br>var self = this, <br>fun = function(){ <br>self.isloop = true; <br>}; <br>if(this.funList[this .index] && typeof this.funList[this.index].fun != 'function'){ <br>this.funList[this.index].fun = fun; <br>this.index ; <br>}else { <br>this.funList[this.index] = {'m':0,'fun':fun}; <br>} <br>this.start(); <br>} <br>}; <br>var d = new Delay(); <br>d.wait(3000).run(function(m){ <br>alert('Once upon a time there was a mountain'); <br>}).wait(2000) .run(function(m){ <br>alert('There is a temple in the mountain'); <br>}).wait(2000).run(function(m){ <br>alert('There is an old man in the temple A monk tells a story to a young monk'); <br>}).wait(2000).run(function(m){ <br>alert('The story told is:'); <br>}).goStart( ); <br></script></body> <br></html> <br><br> </div></div><div class="nphpQianMsg"><div class="clear"></div></div><div class="nphpQianSheng"><span>Statement:</span><div>The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn</div></div></div><div class="nphpSytBox"><span>Previous article:<a class="dBlack" title="Organizing the properties and methods of DOM and XMLHttpRequest objects_javascript skills" href="https://m.php.cn/faq/19290.html">Organizing the properties and methods of DOM and XMLHttpRequest objects_javascript skills</a></span><span>Next article:<a class="dBlack" title="Organizing the properties and methods of DOM and XMLHttpRequest objects_javascript skills" href="https://m.php.cn/faq/19292.html">Organizing the properties and methods of DOM and XMLHttpRequest objects_javascript skills</a></span></div><div class="nphpSytBox2"><div class="nphpZbktTitle"><h2>Related articles</h2><em><a href="https://m.php.cn/article.html" class="bBlack"><i>See more</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/faq/1609.html" title="An in-depth analysis of the Bootstrap list group component" class="aBlack">An in-depth analysis of the Bootstrap list group component</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/faq/1640.html" title="Detailed explanation of JavaScript function currying" class="aBlack">Detailed explanation of JavaScript function currying</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/faq/1949.html" title="Complete example of JS password generation and strength detection (with demo source code download)" class="aBlack">Complete example of JS password generation and strength detection (with demo source code download)</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/faq/2248.html" title="Angularjs integrates WeChat UI (weui)" class="aBlack">Angularjs integrates WeChat UI (weui)</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/faq/2351.html" title="How to quickly switch between Traditional Chinese and Simplified Chinese with JavaScript and the trick for websites to support switching between Simplified and Traditional Chinese_javascript skills" class="aBlack">How to quickly switch between Traditional Chinese and Simplified Chinese with JavaScript and the trick for websites to support switching between Simplified and Traditional Chinese_javascript skills</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>Public welfare online PHP training,Help PHP learners grow quickly!</p></div><div class="footermid"><a href="https://m.php.cn/about/us.html">About us</a><a href="https://m.php.cn/about/disclaimer.html">Disclaimer</a><a href="https://m.php.cn/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>