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

到了搜狐后比较忙,很久没在园子里写随笔了~~

这篇文章主要介绍“在js里面怎么延时执行一个函数?”

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

扩站Function对象增加delay方法如下:

ContractedBlock.gif ExpandedBlockStart.gif 代码
 
   
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插件的控制台下面测试下,代码如:

ContractedBlock.gif ExpandedBlockStart.gif 代码
 
   
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 " );

 

转载于:https://www.cnblogs.com/mamboer/archive/2010/07/05/1771471.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值