JS睡眠函数用法

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_40981281/article/details/80297789

/*
* 先从正常的延时执行说起,以下代码会在2s后弹出true,OK
*/

[html] view plain copy
  1. function st(){  
  2.        alert(true);  
  3. }  
  4. setTimeout(st, 2000);  


/*
* 下面的代码也会弹出true,但不OK,因为延时没有起作用
*/

[html] view plain copy
  1. function st(arg){  
  2.        alert(arg);  
  3. }  
  4. setTimeout(st(true), 2000);  


/*
* 解决方法之一,这种方法可以应付参数为字符串型的,对object型就不OK了
*/

[html] view plain copy
  1. function st(arg){  
  2.        alert(arg);  
  3. }  
  4. setTimeout('st('+ true +')', 2000);  


/*
* 解决方法之二,可以利用闭包
*/

[html] view plain copy
  1. function st(arg){  
  2.        return function(){alert(arg);}  
  3. }  
  4. var st1 = st(true);  
  5. setTimeout(st1, 2000);  


/*
* 解决方法之三,可以重载 window.setTimeout 函数,代码转载有修改,这里也有用到闭包的概念
*/
[html] view plain copy
  1. var _st = window.setTimeout;  
  2. window.setTimeout = function(fRef, mDelay){  
  3.        if(typeof fRef == 'function'){  
  4.               var argu = Array.prototype.slice.call(arguments,2);  
  5.               var f = function(){  
  6.                      fRef.apply(null, argu);  
  7.               };  
  8.               return _st(f, mDelay);  
  9.        }  
  10.        return _st(fRef,mDelay);  
  11. }  
  12. function st(arg){  
  13.        alert(arg);  
  14. }  
  15. setTimeout(st, 2000, true);  
展开阅读全文

没有更多推荐了,返回首页