日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

jQuery 计时器(jquery timers)简单应用

發布時間:2025/3/11 编程问答 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 jQuery 计时器(jquery timers)简单应用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

jquery timers 代碼(版本1.2):

jquery timers /**
* jQuery.timers - Timer abstractions for jQuery
* Written by Blair Mitchelmore (blair DOT mitchelmore AT gmail DOT com)
* Licensed under the WTFPL (http://sam.zoy.org/wtfpl/).
* Date: 2009/10/16
*
* @author Blair Mitchelmore
* @version 1.2
*
*
*/

jQuery.fn.extend({
everyTime:
function(interval, label, fn, times) {
return this.each(function() {
jQuery.timer.add(
this, interval, label, fn, times);
});
},
oneTime:
function(interval, label, fn) {
return this.each(function() {
jQuery.timer.add(
this, interval, label, fn, 1);
});
},
stopTime:
function(label, fn) {
return this.each(function() {
jQuery.timer.remove(
this, label, fn);
});
}
});

jQuery.extend({
timer: {
global: [],
guid:
1,
dataKey:
"jQuery.timer",
regex:
/^([0-9]+(?:\.[0-9]*)?)\s*(.*s)?$/,
powers: {
// Yeah this is major overkill...
'ms': 1,
'cs': 10,
'ds': 100,
's': 1000,
'das': 10000,
'hs': 100000,
'ks': 1000000
},
timeParse:
function(value) {
if (value == undefined || value == null)
return null;
var result = this.regex.exec(jQuery.trim(value.toString()));
if (result[2]) {
var num = parseFloat(result[1]);
var mult = this.powers[result[2]] || 1;
return num * mult;
}
else {
return value;
}
},
add:
function(element, interval, label, fn, times) {
var counter = 0;

if (jQuery.isFunction(label)) {
if (!times)
times
= fn;
fn
= label;
label
= interval;
}

interval
= jQuery.timer.timeParse(interval);

if (typeof interval != 'number' || isNaN(interval) || interval < 0)
return;

if (typeof times != 'number' || isNaN(times) || times < 0)
times
= 0;

times
= times || 0;

var timers = jQuery.data(element, this.dataKey) || jQuery.data(element, this.dataKey, {});

if (!timers[label])
timers[label]
= {};

fn.timerID
= fn.timerID || this.guid++;

var handler = function() {
if ((++counter > times && times !== 0) || fn.call(element, counter) === false)
jQuery.timer.remove(element, label, fn);
};

handler.timerID
= fn.timerID;

if (!timers[label][fn.timerID])
timers[label][fn.timerID]
= window.setInterval(handler,interval);

this.global.push( element );

},
remove:
function(element, label, fn) {
var timers = jQuery.data(element, this.dataKey), ret;

if ( timers ) {

if (!label) {
for ( label in timers )
this.remove(element, label, fn);
}
else if ( timers[label] ) {
if ( fn ) {
if ( fn.timerID ) {
window.clearInterval(timers[label][fn.timerID]);
delete timers[label][fn.timerID];
}
}
else {
for ( var fn in timers[label] ) {
window.clearInterval(timers[label][fn]);
delete timers[label][fn];
}
}

for ( ret in timers[label] ) break;
if ( !ret ) {
ret
= null;
delete timers[label];
}
}

for ( ret in timers ) break;
if ( !ret )
jQuery.removeData(element,
this.dataKey);
}
}
}
});

jQuery(window).bind(
"unload", function() {
jQuery.each(jQuery.timer.global,
function(index, item) {
jQuery.timer.remove(item);
});
});

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
??}
可以定制自己想要的了!

【出自:http://www.xueit.com/html/2009-12-25/33-440792138906.html】

總結

以上是生活随笔為你收集整理的jQuery 计时器(jquery timers)简单应用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。