最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

jQuerytimers計(jì)時器簡單應(yīng)用說明_jquery

來源:懂視網(wǎng) 責(zé)編:小采 時間:2020-11-27 20:55:29
文檔

jQuerytimers計(jì)時器簡單應(yīng)用說明_jquery

jQuerytimers計(jì)時器簡單應(yīng)用說明_jquery:因?yàn)榉奖懵铮琂query已封裝JS的setTimeout 和 setInterval 方法,下面看下應(yīng)用例子: 代碼如下: /** * jQuery.timers - Timer abstractions for jQuery * Written by Blair Mitchelmore (blair DOT mitchelmo
推薦度:
導(dǎo)讀jQuerytimers計(jì)時器簡單應(yīng)用說明_jquery:因?yàn)榉奖懵铮琂query已封裝JS的setTimeout 和 setInterval 方法,下面看下應(yīng)用例子: 代碼如下: /** * jQuery.timers - Timer abstractions for jQuery * Written by Blair Mitchelmore (blair DOT mitchelmo

因?yàn)榉奖懵铮琂query已封裝JS的setTimeout 和 setInterval 方法,下面看下應(yīng)用例子:
代碼如下:
/**
* 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);
});
});

JS Code
代碼如下:
$("#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應(yīng)用知識

提供了三個函式
1. everyTime(時間間隔, [計(jì)時器名稱], 函式名稱, [次數(shù)限制], [等待函式程序完成])
2. oneTime(時間間隔, [計(jì)時器名稱], 呼叫的函式)
3. stopTime ([計(jì)時器名稱], [函式名稱])
代碼如下:
/*************************************************************
* everyTime(時間間隔, [計(jì)時器名稱], 函式名稱, [次數(shù)限制], [等待函式程序完成])
*************************************************************/

//每1秒執(zhí)行函式test()
function test(){
//do something...
}
$('body').everyTime('1s',test);

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

//每1秒執(zhí)行,并命名計(jì)時器名稱為A
$('body').everyTime('1s','A',function(){
//do something...
});

//每20秒執(zhí)行,最多5次,并命名計(jì)時器名稱為B
$('body').everyTime('2das','B',function(){
//do something...
},5);

//每20秒執(zhí)行,無限次,并命名計(jì)時器名稱為C
//若時間間隔抵到,但函式程序仍未完成則需等待執(zhí)行函式完成后再繼續(xù)計(jì)時
$('body').everyTime('2das','C',function(){
//執(zhí)行一個會超過20秒以上的程式
},0,true);

/***********************************************************
* oneTime(時間間隔, [計(jì)時器名稱], 呼叫的函式)
***********************************************************/
//倒數(shù)10秒后執(zhí)行
$('body').oneTime('1das',function(){
//do something...
});

//倒數(shù)100秒后執(zhí)行,并命名計(jì)時器名稱為D
$('body').oneTime('1hs','D',function(){
//do something...
});

/************************************************************
* stopTime ([計(jì)時器名稱], [函式名稱])
************************************************************/
//停止所有的在$('body')上計(jì)時器
$('body').stopTime ();

//停止$('body')上名稱為A的計(jì)時器
$('body').stopTime ('A');

//停止$('body')上所有呼叫test()的計(jì)時器
$('body').stopTime (test);

自定義時間單位
打開源代碼
找到
代碼如下:
powers: {
// Yeah this is major overkill...
'ms': 1,
'cs': 10,
'ds': 100,
's': 1000,
'das': 10000,
'hs': 100000,
'ks': 1000000
}

可以定制自己想要的了!

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

jQuerytimers計(jì)時器簡單應(yīng)用說明_jquery

jQuerytimers計(jì)時器簡單應(yīng)用說明_jquery:因?yàn)榉奖懵?,Jquery已封裝JS的setTimeout 和 setInterval 方法,下面看下應(yīng)用例子: 代碼如下: /** * jQuery.timers - Timer abstractions for jQuery * Written by Blair Mitchelmore (blair DOT mitchelmo
推薦度:
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top