jQuery插件開發(fā)發(fā)送短信倒計時功能代碼
實現(xiàn)的主要功能如下:
1.點擊按鈕的時候,可以進(jìn)行倒計時,倒計時自定義。
2.當(dāng)接收短信失敗后,倒計時停止,可點擊重新發(fā)送短信。
3.點擊的元素支持一般標(biāo)簽和input標(biāo)簽。
html代碼:
<input type="button" class="sameBtn btnCur" value="發(fā)送驗證碼"/> <div class="sameBtn btnCur2">發(fā)送驗證碼</div>
css代碼:
body{padding:100px;text-align: center;}
.sameBtn{display: inline-block;font-size:12px;cursor:pointer;width:76px;height:25px;line-height: 25px;text-align: center;border:0;background: #3186df;color:#fff;}
.sameBtn.current{background: #b1b1b1;}
js代碼:
//短信倒計時功能
/**使用方式如下:
* $(".btnCur").CountDownF({
* time:120,
* resetWords:'重新發(fā)送', //文字定義
* cnSeconds:'s',//倒計時中顯示中文的秒,還是s
* clickClass:'current', //點擊后添加的class類
* countState:true,
* callback:function(){
* setTimeout(function(){
* //當(dāng)發(fā)送失敗后,可以立即清除倒計時與其狀態(tài)
* $(".btnCur").CountDownF('clearState');
* },3000);
* }
* });
*
* */
;(function($,window,document,undefined){
var pluginName = 'CountDownF',
defaluts = {
time:120,
resetWords:'重新發(fā)送', //文字定義
cnSeconds:'s',//倒計時中顯示中文的秒,還是s
clickClass:'current', //點擊后添加的class類
countState:true //是否可以倒計時,true可以倒計時,false不能進(jìn)行倒計時
}
function Count(element,options){
this.element = element;
this.$element = $(this.element);
this.state = true;
this.settings = $.extend({},defaluts,options);
this.number = this.settings.time;
this.init();
}
Count.prototype = {
init:function(){
var self = this;
self.$element.on('click',function(){
if(self.state && self.settings.countState){
self.state = false;
if(self.settings.countState){
self._count();
}
if(self.settings.callback){
self.settings.callback();
}
}
});
},
//倒計時函數(shù)
_count:function(){
var self = this;
if(self.number == 0){
self._clearInit();
}else{
if(self.number < 10){
//如果當(dāng)前元素是input,使用val賦值
this.$element.attr('type') ? this.$element.val('0' + self.number + self.settings.cnSeconds) : this.$element.html('0' + self.number + self.settings.cnSeconds);
}else{
this.$element.attr('type') ? this.$element.val(self.number + self.settings.cnSeconds) : this.$element.html(self.number + self.settings.cnSeconds);
}
self.number--;
this.$element.addClass(self.settings.clickClass);
self.clearCount = setTimeout(function(){
self._count();
},1000);
}
},
//修改是否可發(fā)送短信驗證碼倒計時狀態(tài)
change:function(state){
var self = this;
self.settings.countState = state;
},
//置為初始狀態(tài)
_clearInit:function(){
var self = this;
self.$element.removeClass(self.settings.clickClass);
self.$element.attr('type') ? self.$element.val(self.settings.resetWords) : self.$element.html(self.settings.resetWords);
clearTimeout(self.clearCount);
self.number = self.settings.time;
self.state = true;
},
//清除倒計時進(jìn)行狀態(tài)
clearState:function(){
var self = this;
self._clearInit();
}
};
$.fn.CountDownF = function(options){
var args = arguments;
if(options === undefined || typeof options ==='object' ){
return this.each(function(){
if(!$.data(this,'plugin' + pluginName)){
$.data(this,'plugin' + pluginName,new Count(this,options));
}
});
}
else if(typeof options === 'string' && options !== 'init'){
var returns;
this.each(function(){
var data = $.data(this,'plugin' + pluginName);
if(data instanceof Count && typeof data[options] === 'function'){
returns = data[options].apply(data,Array.prototype.slice.call(args,1));
}
if(options === 'destory'){
$.data(this, 'plugin' + pluginName, null);
}
});
return returns !== undefined ? returns : this;
}
else{
$.error('Method' + options + 'does not exist on jQuery.CountDownF');
}
}
})(jQuery,window,document);
調(diào)用方式:
$(function(){
$(".btnCur").CountDownF({
time:120,
countState:true,
callback:function(){
setTimeout(function(){
$(".btnCur").CountDownF('clearState');
},3000);
}
});
$(".btnCur2").CountDownF({
time:50,
countState:true,
cnSeconds:'秒',
callback:function(){
setTimeout(function(){
$(".btnCur2").CountDownF('clearState');
},5000);
}
});
})
github地址:https://github.com/hxlmqtily1314/sms_countdown
以上所述是小編給大家介紹的jQuery插件開發(fā)發(fā)送短信倒計時功能代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Jquery 獲取指定標(biāo)簽的對象及屬性的設(shè)置與移除
這篇文章主要介紹了Jquery如何獲取指定標(biāo)簽的對象及屬性的設(shè)置與移除,需要的朋友可以參考下2014-05-05
原生Ajax 和jQuery Ajax的區(qū)別示例分析
這篇文章主要介紹了原生Ajax 和Jq Ajax的區(qū)別示例分析,需要的朋友可以參考下2014-12-12
jQuery+AJAX實現(xiàn)網(wǎng)頁無刷新上傳
這篇文章主要介紹了jQuery+AJAX實現(xiàn)網(wǎng)頁無刷新上傳的相關(guān)資料,十分詳細(xì),需要的朋友可以參考下2015-02-02
jQuery學(xué)習(xí)筆記之 Ajax操作篇(三) - 過程處理
對于 jQuery 通過 Ajax 方式傳遞數(shù)據(jù)時,我們還可以在過程中進(jìn)行一定的處理,以便達(dá)到我們的需求。2014-06-06
使用jquery.form.js實現(xiàn)圖片上傳的方法
這篇文章主要介紹了使用jquery.form.js實現(xiàn)圖片上傳的方法,涉及jquery使用表單插件jquery.form.js進(jìn)行圖片上傳的提交、類型驗證、執(zhí)行結(jié)果回調(diào)顯示等技巧,非常簡單實用,需要的朋友可以參考下2016-05-05

