Javascript Function对象扩展之延时执行函数
2010-07-06 00:00
781 查看
不就利用window对象的setTimeout方法吗?Bingo,一点没错!如果你在一个应用里面常常要“延时执行某某函数”,那末基于DRY的原则,可以针对Function全局对象进行扩展,为函数增加一个延时方法如delay,这样会让你的代码更简洁有效。
扩站Function对象增加delay方法如下:
在firefox的firebug插件的控制台下面测试下,代码如:
扩站Function对象增加delay方法如下:
Function.prototype.delay=function(this1,timeout){ this1=this1||null; timeout=timeout||0; var _this=this; var args=[]; //获取参数,注:第1、第2个参数是保留参数 switch(arguments.length){ case 1: timeout=parseInt(arguments[0]); timeout=isNaN(timeout)?0:timeout; timeout=timeout<0?0:timeout; break; default: for(var i=0;i<arguments.length;i++){ if(i>1){args.push(arguments[i]);}; }; break; }; var proxy=function(){ _this.apply(this1,args); }; return window.setTimeout(proxy,timeout); };
在firefox的firebug插件的控制台下面测试下,代码如:
var xx=function(n){ this.name=n; }; xx.prototype.hi=function(a,b){ console.log(this.name+"-"+a+"-"+b); }; var xx1=new xx("levin"); var t=xx1.hi.delay(xx1,1000,"cocoa","yoyo"); xx1.hi("guluglu","jigujigu");
相关文章推荐
- Javascript实践-Function对象扩展之延时执行函数
- Javascript Function对象扩展之延时执行函数
- js Function对象扩展与延时执行函数实例代码
- js Function对象扩展与延时执行函数实例代码
- javascript 扩展Function对象 获取函数名称
- javascript Function对象的length属性及js函数的预执行
- JavaScript延时执行函数中对call和apply的应用
- 深入理解javascript中的立即执行函数(function(){…})()
- Javascript中,有一个函数,执行时对象查找时,永远不会去查找原型,这个函数是?
- JavaScript中的Function(函数)对象
- 【Function类型】JavaScript中的原生对象以及Microsoft AJAX Library中的相关扩展
- 深入理解javascript中的立即执行函数(function(){…})()
- Javascript中的函数(Function)与对象(Object)的关系
- 深入理解JavaScript中的立即执行函数(function(){……})()
- 深入理解javascript中的立即执行函数(function(){…})()
- Javascript对象 Object 与函数 Function
- javascript延时重复执行函数 lLoopRun.js
- 理解javascript中的立即执行函数(function(){})()
- JavaScript之基础-13 JavaScript Functions (Function对象、创建函数、匿名函数、闭包)
- javascript中的立即执行函数(function(){…})()