转自: http://www.blogjava.net/emu/archive/2005/06/20/6365.html 1 <html><head><title>emu -- 用fason的参数化定时器模拟多线程</title></head><body> 2 data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt="" <SCRIPT LANGUAGE="JavaScript">data:image/s3,"s3://crabby-images/84374/8437476b83531729029df2c7c5e65dc4db1051cf" alt="" 3 <!-- 4 data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt="" 5 var _st = window.setTimeout; 6 data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" window.setTimeout = function(fRef, mDelay) { 7 data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" if(typeof fRef == 'function') { 8 var argu = Array.prototype.slice.call(arguments,2); 9 data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" var f = (function() { fRef.apply(null, argu); }); 10 return _st(f, mDelay); 11 } 12 return _st(fRef,mDelay); 13 } 14data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt="" 15 var _int = window.setInterval; 16data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" window.setInterval = function(fRef, mDelay) { 17data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" if(typeof fRef == 'function') { 18 var argu = Array.prototype.slice.call(arguments,2); 19data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" var f = (function() { fRef.apply(null, argu); }); 20 return _int(f, mDelay); 21 } 22 return _st(fRef,mDelay); 23 } 24data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt="" 25data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt="" 26data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" function startNewTask() { 27 var target = document.getElementById("sampleResult").cloneNode(true); 28data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" with (target) { 29 id="";style.display="block";style.color=(Math.floor(Math.random()* (1<<23)).toString(16)+"00000").substring(0,6); 30 } 31 document.body.insertBefore(target,document.body.lastChild); 32data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" var parameter = {target:target,n:0,result:0} 33 parameter.timer = setInterval(count,1,parameter); 34 } 35data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt="" 36data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" function count(parameter) { 37data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" with (parameter) { 38data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" if (!target.stop) { 39 for(var i=0;i<speed;i++) 40 if (n<MAX) result += ++n; 41 target.innerHTML = result; 42 } 43data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" if (n>=MAX) { 44 clearInterval(timer); 45data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" setTimeout(function(elm) {document.body.removeChild(elm)},2000,target); 46 } 47 } 48 } 49data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt="" 50 var speed = 1111; 51 var MAX=100000; 52 //--> 53 </SCRIPT> 54 <button onclick="startNewTask()">开始新线程</button> 55data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt="" 56 <BR><BR> 57 <div id=sampleResult onmouseover="this.stop=true" onmouseout="this.stop=false" style="display:none;cursor:hand">0</div> 58 </body> 59 </html>
|