当前位置:Gxlcms > JavaScript > Javascript Function对象扩展之延时执行函数

Javascript Function对象扩展之延时执行函数

时间:2021-07-01 10:21:17 帮助过:3人阅读

不就利用window对象的setTimeout方法吗?Bingo,一点没错!如果你在一个应用里面常常要“延时执行某某函数”,那末基于DRY的原则,可以针对Function全局对象进行扩展,为函数增加一个延时方法如delay,这样会让你的代码更简洁有效。
扩站Function对象增加delay方法如下:
代码如下:

  1. <br>Function.prototype.delay=function(this1,timeout){ <br>this1=this1||null; <br>timeout=timeout||0; <br>var _this=this; <br>var args=[]; <br>//获取参数,注:第1、第2个参数是保留参数 <br>switch(arguments.length){ <br>case 1: <br>timeout=parseInt(arguments[0]); <br>timeout=isNaN(timeout)?0:timeout; <br>timeout=timeout<0?0:timeout; <br>break; <br>default: <br>for(var i=0;i<arguments.length;i++){ <br>if(i>1){args.push(arguments[i]);}; <br>}; <br>break; <br>}; <br>var proxy=function(){ <br>_this.apply(this1,args); <br>}; <br>return window.setTimeout(proxy,timeout); <br>}; <br> <br>在firefox的firebug插件的控制台下面测试下,代码如: <br><span><u></u></span> 代码如下:<pre class="brush:php;toolbar:false layui-box layui-code-view layui-code-notepad"><ol class="layui-code-ol"><li><br>var xx=function(n){ <br>this.name=n; <br>}; <br>xx.prototype.hi=function(a,b){ <br>console.log(this.name+"-"+a+"-"+b); <br>}; <br>var xx1=new xx("levin"); <br>var t=xx1.hi.delay(xx1,1000,"cocoa","yoyo"); <br>xx1.hi("guluglu","jigujigu"); <br> <p></p></li><li> </li><li> </li></ol></pre>

人气教程排行