setTimeoutºÍsetIntervalÄãÕæµÄÁ˽âÂð?
setTimeoutºÍsetIntervalÕâÁ½¸öº¯Êý, ´ó¼Ò¿Ï¶¨¶¼²»Ä°Éú, µ«¿ÉÄܲ¢²»ÊÇÿ¸öÓùýÕâÁ½¸ö·½·¨µÄͬѧ, ¶¼Á˽âÆäÄÚ²¿µÄʵÖÊ, ÉõÖÁ¿ÉÄÜ»á´íÎóµÄ°ÑÁ½¸öʵÏÖ¶¨Ê±µ÷Óõĺ¯ÊýÀí½â³ÉÁËÀàËÆthreadÒ»ÑùµÄ¶«Î÷, ÈÏΪ»áÔÚÒ»¸öʱ¼äƬÄÚ, ²¢·¢µÄÖ´Ðе÷Óõĺ¯Êý, ËƺõºÜºÃºÜÇ¿´ó, µ«Æäʵ²¢²»ÊÇÈç´Ë, ʵ¼ÊµÄÇé¿öÊÇjavascript¶¼ÊÇÒÔµ¥Ï̵߳ķ½Ê½ÔËÐÐÓÚä¯ÀÀÆ÷µÄjavascriptÒýÇæÖеÄ, setTimeoutºÍsetIntervalµÄ×÷ÓÃÖ»ÊÇ°ÑÄãÒªÖ´ÐеĴúÂëÔÚÄãÉ趨µÄÒ»¸öʱ¼äµã²åÈëjsÒýÇæά»¤µÄÒ»¸ö´úÂë¶ÓÁÐÖÐ, ²åÈë´úÂë¶ÓÁв¢²»Òâζ×ÅÄãµÄ´úÂë¾Í»áÁ¢ÂíÖ´ÐеÄ,Àí½âÕâÒ»µãºÜÖØÒª. ¶øÇÒsetTimeoutºÍsetInterval»¹Óе㲻һÑù.
ÏÈ̸̸setTimeout
function click() { // code block1... setTimeout(function() { // process ... }, 200); // code block2 }
¼ÙÉèÎÒÃǸøÒ»¸öbuttonµÄonclickʼþ°ó¶¨ÁË´Ë·½·¨, µ±ÎÒÃÇ°´Ï°´Å¥ºó, ¿Ï¶¨ÏÈÖ´ÐÐblock1µÄÄÚÈÝ, È»ºóÔËÐе½setTimeoutµÄµØ·½, setTimeout»á¸æËßä¯ÀÀÆ÷˵, "200msºóÎÒ»á²åÒ»¶ÎÒªÖ´ÐеĴúÂë¸øÄãµÄ¶ÓÁÐÖÐ", ä¯ÀÀÆ÷µ±È»´ðÓ¦ÁË(×¢Òâ²åÈë´úÂë²¢²»Òâζ×ÅÁ¢ÂíÖ´ÐÐ), setTimeout´úÂëÔËÐкó, ½ô¸úÆäºóµÄblock2´úÂ뿪ʼִÐÐ, ÕâÀï¾Í¿ªÊ¼ËµÃ÷ÎÊÌâÁË, Èç¹ûblock2µÄ´úÂëÖ´ÐÐʱ¼ä³¬¹ý200ms, Äǽá¹û»áÊÇÈçºÎ? »òÐí°´ÕÕÄã֮ǰµÄÀí½â, »áÀíËùµ±È»µÄÈÏΪ200msÒ»µ½, ÄãµÄprocess´úÂë»áÁ¢ÂíÖ´ÐÐ...ÊÂʵÊÇ, ÔÚblock2Ö´Ðйý³ÌÖÐ(Ö´ÐÐÁË200msºó)process´úÂë±»²åÈë´úÂë¶ÓÁÐ, µ«Ò»Ö±ÒªµÈclick·½·¨Ö´ÐнáÊø, ²Å»áÖ´ÐÐprocess´úÂë¶Î, ´Ó´úÂë¶ÓÁÐÉÏ¿´process´úÂëÊÇÔÚclickºóÃæµÄ, ÔÙ¼ÓÉÏjsÒÔµ¥Ï̷߳½Ê½Ö´ÐÐ, ËùÒÔÓ¦¸Ã²»ÄÑÀí½â. Èç¹ûÊÇÁíÒ»ÖÖÇé¿ö, block2´úÂëÖ´ÐеÄʱ¼ä<200ms, setTimeoutÔÚ200msºó½«process´úÂë²åÈëµ½´úÂë¶ÓÁÐ, ¶øÄÇʱִÐÐÏ߳̿ÉÄÜÒѾ´¦ÓÚ¿ÕÏÐ״̬ÁË(idle), Äǽá¹û¾ÍÊÇ200msºó, process´úÂë²åÈë¶ÓÁоÍÁ¢ÂíÖ´ÐÐÁË, ¾ÍÈÃÄã¸Ð¾õ200msºó, ¾ÍÖ´ÐÐÁË.
ÔÙ¿´¿´setInterval
ÕâÀï¿ÉÄÜ»á´æÔÚÁ½¸öÎÊÌâ:
1.ʱ¼ä¼ä¸ô»òÐí»áÌø¹ý
2.ʱ¼ä¼ä¸ô¿ÉÄÜ<¶¨Ê±µ÷ÓõĴúÂëµÄÖ´ÐÐʱ¼ä
function click() { // code block1... setInterval(function() { // process ... }, 200); // code block2 }
ºÍÉÏÃæÒ»ÑùÎÒÃǼÙÉèͨ¹ýÒ»¸öclick, ´¥·¢ÁËsetIntervalÒÔʵÏÖÿ¸ôÒ»¸öʱ¼ä¶ÎÖ´ÐÐprocess´úÂë
±ÈÈçonclickÒª300msÖ´ÐÐÍê, block1´úÂëÖ´ÐÐÍê, ÔÚ5msʱִÐÐsetInterval, ÒÔ´ËΪһ¸öʱ¼äµã, ÔÚ205msʱ²åÈëprocess´úÂë, click´úÂë˳Àû½áÊø, process´úÂ뿪ʼִÐÐ(Ï൱ÓÚͼÖеÄtimer code), È»¶øprocess´úÂëÒ²Ö´ÐÐÁËÒ»¸ö±È½Ï³¤µÄʱ¼ä, ³¬¹ýÁ˽ÓÏÂÀ´Ò»¸ö²åÈëʱ¼äµã405ms, ÕâÑù´úÂë¶ÓÁкóÓÖ²åÈëÁËÒ»·Ýprocess´úÂë, process¼ÌÐøÖ´ÐÐ×Å, ¶øÇÒ³¬¹ýÁË605msÕâ¸ö²åÈëʱ¼äµã, ÏÂÃæÎÊÌâÀ´, ¿ÉÄÜÄ㻹»áÈÏΪ´úÂë¶ÓÁкóÃæÓÖ»á¼ÌÐø²åÈëÒ»·Ýprocess´úÂë...ÕæʵµÄÇé¿öÊÇ,ÓÉÓÚ´úÂë¶ÓÁÐÖÐÒѾÓÐÁËÒ»·ÝδִÐеÄprocess´úÂë, ËùÒÔ605msÕâ¸ö²åÈëʱ¼äµã½«»á±»"ÎÞÇé"µÄÌø¹ý, ÒòΪjsÒýÇæÖ»ÔÊÐíÓÐÒ»·ÝδִÐеÄprocess´úÂë, ˵µ½ÕâÀï²»ÖªµÀÄúÊDz»ÊÇ»á»íÈ»¿ªÀÊÄØ...
ΪÁËÕâÖÖÇé¿öÄã¿ÉÒÔÓÃÒ»ÖÖ¸üºÃµÄ´úÂëÐÎʽ
setTimeout(function(){ //processing setTimeout(arguments.callee, interval); }, interval);
Õâ¸ö¹À¼ÆÉÔ΢ÏëÒ»ÏÂ, ¾ÍÃ÷°×ÆäÖеĺô¦ÁË, ÕâÑù¾Í²»»á²úÉúʱ¼äµã±»Ìø¹ýµÄÎÊÌâ
ÄÚÈݾ͵½ÕâÀï, Ï£ÍûÄÜÓÐËù°ïÖú, ¿ÉÄÜÎÒ±í´ïµÄ²»ÊǺÜÇå³þ
Èç¹û¾õµÃ×Ô¼ºÓ¢Óï»ù´¡²»´í¿ÉÒÔÖ±½Ó¿´
ÀïÓйØadvanced TimersÕâ½ÚÄÚÈÝ, ¸öÈËÈÏΪÕâ±¾ÊéÕæµÄºÜ²»´í, ÎÞÂÛÊÇÏë´ÓÁãѧÆð, »¹ÊÇƽÈÕûÊ··²Î¿¼²Î¿¼ ¶¼ºÜ²»´í, ×÷ÕßÊÇyahooÀïºÜÅ£µÄһλǰ¶Ë¿ª·¢¹¤³Ìʦ : )
ÍƼöÐÅÏ¢
- jqueryʵÏÖÍøվͼƬÀÁ¼ÓÔØ´úÂë
- jQuery Tooltips²å¼þ
- jQueryµÄ.bind()¡¢.live()ºÍ.delegate(....
- [Ô´´]·ÂGoogle Reader¡¢ÐÂÀË΢²©¡¢ÌÚѶ΢²©µ....
- Ä㲻ϲ»¶»ðºü£¬µ«ÓÖϲ»¶firebug£¬ÄǾ͸úÎÒÒ»ÆðÀ´ÔÚIEÉÏ....
- ¸ù¾ÝÏÔʾÆ÷·Ö±æÂʵ÷ÕûÒ³ÃæÏÔʾµÄJavascript½Å±¾
- jQuery дµÄ·ÂÐÂÀË΢²© ÏòϹö¶¯Ð§¹û¡¾×ªÔØ¡¿
- ͨÓõÄJqueryÑ¡ÔñÆ÷
- jQuery ½áºÏ Json Ìá½»Êý¾Ýµ½Webservice£¬....
- ×ÔÖÆjQueryÖÇÄÜÌáʾ²å¼þһö
ÈÈÃÅÐÅÏ¢
- nohup: redirecting stderr to stdou....
- ʹÓÃlog_formatΪNginx·þÎñÆ÷ÉèÖøüÏêϸµÄÈÕÖ¾¸ñʽ
- jquery easyUI--dataGrid-Json
- [Ô´´]·ÂGoogle Reader¡¢ÐÂÀË΢²©¡¢ÌÚѶ΢²©µ....
- ÀûÓÃKeepalived+mysql¹¹½¨¸ß¿ÉÓÃMySQLË«Ö÷×Ô¶....
- Nginx+keepalivedʵÏÖ¸ºÔؾùºâºÍË«»úÈȱ¸¸ß¿ÉÓÃ
- jqueryʵÏÖÒ³Ãæ¼ÓÔؽø¶ÈÌõ
- Rolling cURL: PHP²¢·¢×î¼Ñʵ¼ù
- codeigniter ·ÓÉÖÕ¼«ÓÅ»¯(url rewrite)
- linuxÏÂÉèÖÃsshÎÞÃÜÂëµÇ¼
×î½ü¸üÐÂ
- js»ñÈ¡srcÖд«µÝµÄ²ÎÊý
- jqueryʵÏÖÍøվͼƬÀÁ¼ÓÔØ´úÂë
- ÈÃä¯ÀÀÆ÷ÆÁ±ÎµôJavaScriptµÄ³ö´íÌáʾ
- github²»ÄܼÓÔØcss¡¢js½â¾ö°ì·¨
- ÎÒÖªµÀµÄJavaScript -- Éè¼Æģʽ(ÇŽÓ)Ó¦ÓÃÖ® ¨C ....
- 15¸öÖµµÃ¿ª·¢ÈËÔ±¹Ø×¢µÄjQuery¿ª·¢¼¼ÇɺÍÐĵÃ
- dz̸JavascriptÃæÏò¶ÔÏó±à³Ì
- JS¼òµ¥¶¯»·â×°
- JavaScript³õѧÕßӦעÒâµÄÆ߸öϸ½Ú
- jQuery Tooltips²å¼þ
ÆÀÂÛ