Jquery中文網 www.4271936.live
Jquery中文網 >  jQuery  >  jquery 教程  >  正文 基于jQuery的倒計時插件代碼

基于jQuery的倒計時插件代碼

發布時間:2013-07-04   編輯:www.4271936.live
jQuery倒計時插件,主要用來限時購買,需要的朋友可以參考下。
jquery倒計時插件,主要用來限時購買,需要的朋友可以參考下。 剩余時間:1小時:40分:30秒
復制代碼 代碼如下:

1 /*
* 倒計時插件,主要用來限時購買
* By wayshan 版本1.0
* 使用方法:
* $(function(){
* $("#ElementId").countdown({
* Edate:"2012-12-21 15:14:23"
* });
* })

*/
;(function($){
$.fn.countdown = function(options){
if (this.length == 0){
return false;
}
return this.each(function(){
var Default = {
Sdate:null,//開始時間(格式為“2010-10-10 10:10:10”)可以設置為服務端的時間
Edate:null,//結束日期(格式為“2010-10-10 10:10:10”)
callback:function(){
return false;
}
},
_H_Text='小時',
_M_Text='分',
_S_Text='秒',
_lT = null,
_cT = new Date(),
_eT = null,
_elT = null,
ctime = null,
etime = null,
DomId = null,
_timeout = null,
_gt = function(){
if (_lT == null) {
_elT = (etime - ctime);
if (_elT < 0){
$('#'+DomId).html("<strong>0</strong>"+_H_Text+":<strong>0</strong>"+
_M_Text+":<strong>0</strong>"+_S_Text);
}
var _xT =Math.ceil(_elT/(24*60*60*1000));
_cT = parseInt(_cT.match(/\s(\d+)\D/)[1] * 3600)
+ parseInt(_cT.split(":")[1] * 60)+ parseInt(_cT.split(":")[2]);
_eT = _xT * 24 * 3600 + parseInt(_eT.match(/\s(\d+)\D/)[1] * 3600)
+ parseInt(_eT.split(":")[1] * 60) + parseInt(_eT.split(":")[2]);
_lT = _elT/1000;
}
if (_elT > 0) {
if (_lT >= 0) {
var _H = Math.floor(_lT / 3600);
var _M = Math.floor((_lT - _H * 3600) / 60);
var _S = (_lT - _H * 3600) % 60;
$('#'+DomId).html("<strong>" + _H + "</strong>"+_H_Text+":<strong>"
+ _M + "</strong>"+_M_Text+":<strong>" + _S + "</strong>"+_S_Text);
_lT--;
} else {
clearInterval(_timeout);
if(s.callback && $.isFunction(s.callback)){
s.callback.call(this);
}
}
} else {
clearInterval(_timeout);
if(s.callback && $.isFunction(s.callback)){
s.callback.call(this);
}
}
},
strDateTime = function(str){
//判斷日期時間的輸入是否正確,類型必須形如為:2011-01-01 01:01:01
var reg = /^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2}) (\d{1,2}):(\d{1,2}):(\d{1,2})$/;
var r = str.match(reg);
if(r==null)return false;
var d= new Date(r[1], r[3]-1,r[4],r[5],r[6],r[7]);
return (d.getFullYear()==r[1]&&(d.getMonth()+1)==r[3]&&d.getDate()==r[4]
&&d.getHours()==r[5]&&d.getMinutes()==r[6]&&d.getSeconds()==r[7]);
}
var s = $.extend({}, Default, options || {});
DomId = this.id;
if (DomId == 'null'){
return;
}
_eT = s.Edate;
if (!strDateTime(_eT)){
alert('結束日期格式不正確');
return false;
}
if (s.Sdate != null){
_cT = s.Sdate;
}
_cT = _cT.toString();
cdate = _cT.replace(/-/g, '/');
_eT = _eT.toString();
edate = _eT.replace(/-/g, '/');
ctime = new Date(cdate);
etime = new Date(edate);
_timeout = setInterval(_gt, 1000)
});
}
})(jQuery);

您可能感興趣的文章:
jquery 倒計時效果實現秒殺思路
javascript倒計時(setTimeout)的示例代碼
JQuery插件fancybox無法在彈出層使用左右鍵的解決辦法
js倒計時(距離結束還有多少時間)的代碼分享
jQuery音樂播放器
jquery插件jquery倒計時插件分享
基于JQuery.timer插件實現一個計時器
JS倒計時代碼(可隨時點擊停止)
jQuery插件開發的兩種方法及$.fn.extend的詳解
團購頁面中多個商品倒計時的js代碼

[關閉]
微信下载APP完成任务如何赚钱 安阳期货配资 炒股的人一生穷 天津快乐10分开奖结果查询 炒股票一天能赚多少钱 云南11选5的最好方法l 期货配资巨亏报案有人管吗 家彩开奖千禧3d试机号 平特一尾公式 在线配资优良卓信宝配资高强 快乐10分钟开奖结果查询