继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

jQuery定时器使用方法,jQuery Timers

quincyye
关注TA
已关注
手记 235
粉丝 168
获赞 3550

Jquery已封装JS的setTimeout 和 setInterval 方法,下面看下应用例子:
JS Code [http://www.xueit.com]$("#close-button").click(function() {
$(this).oneTime(1000, function() {
$(this).parent(".main-window").hide();
});
});
$("#cancel-button").click(function() {
$("#close-button").stopTime();
});

jQuery Timers插件地址:
http://plugins.jquery.com/project/timers

下面来自JavaEye论坛的JQuery Timers应用知识
提供了三个函式

  1. everyTime(时间间隔, [计时器名称], 函式名称, [次数限制], [等待函式程序完成])
  2. oneTime(时间间隔, [计时器名称], 呼叫的函式)
  3. stopTime ([计时器名称], [函式名称])
    /*****
    • everyTime(时间间隔, [计时器名称], 函式名称, [次数限制], [等待函式程序完成])
      *****/
      //每1秒执行函式test()
      function test(){
      //do something...
      }
      $('body').everyTime('1s',test);

//每1秒执行
$('body').everyTime('1s',function(){
//do something...
});

//每1秒执行,并命名计时器名称为A
$('body').everyTime('1s','A',function(){
//do something...
});

//每20秒执行,最多5次,并命名计时器名称为B
$('body').everyTime('2das','B',function(){
//do something...
},5);

//每20秒执行,无限次,并命名计时器名称为C
//若时间间隔抵到,但函式程序仍未完成则需等待执行函式完成后再继续计时
$('body').everyTime('2das','C',function(){
//执行一个会超过20秒以上的程式
},0,true);

/***

  • oneTime(时间间隔, [计时器名称], 呼叫的函式)
    ***/
    //倒数10秒后执行
    $('body').oneTime('1das',function(){
    //do something...
    });

//倒数100秒后执行,并命名计时器名称为D
$('body').oneTime('1hs','D',function(){
//do something...
});

/****

  • stopTime ([计时器名称], [函式名称])
    ****/
    //停止所有的在$('body')上计时器
    $('body').stopTime ();

//停止$('body')上名称为A的计时器
$('body').stopTime ('A');

//停止$('body')上所有呼叫test()的计时器
$('body').stopTime (test);
自定义时间单位
打开源代码
找到
powers: {
// Yeah this is major overkill...
'ms': 1,
'cs': 10,
'ds': 100,
's': 1000,
'das': 10000,
'hs': 100000,
'ks': 1000000
}
可以定制自己想要的单位

打开App,阅读手记
2人推荐
发表评论
随时随地看视频慕课网APP