Extjs源码之---Ext.util.DelayedTask


/*
创建对象
var task = new Ext.util.DelayedTask(function(){
alert(Ext.getDom('myInputField').value.length);
});
调用执行
Ext.get('myInputField').on('keypress', function(){
task.{@link #delay}(500);
});
*/
Ext.util.DelayedTask = function(fn, scope, args){
var me = this,
id,
call = function(){
clearInterval(id);//这里感觉这里有点多余, me.cancel已经有做这个动作,是不是重复了,不知道作者处于何意
id = null;
fn.apply(scope, args || []);
};

//设置delay 参数信息
me.delay = function(delay, newFn, newScope, newArgs){
me.cancel();//先清除当前对象的定期器
fn = newFn || fn;//设置调用函数
scope = newScope || scope;//调用函数的作用域
args = newArgs || args;//调用函数的参数
id = setInterval(call, delay);//运行函数
};

//清楚定时器
me.cancel = function(){
if(id){
clearInterval(id);
id = null;
}
};
};

//这个函数用在对输入校验的时候特别管用,特别是对于suggest这样的应用,可以减少服务端压力,
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值