使用jQuery全局事件ajaxStart為特定請(qǐng)求實(shí)現(xiàn)提示效果的代碼
更新時(shí)間:2010年12月30日 11:45:04 作者:
首先,重寫(xiě)Ajax方法的代價(jià)太高,仍然可以利用jQuery自身的Ajax Events。
情景
如何在特定的請(qǐng)求上實(shí)現(xiàn)"ajaxStart"的效果?
首先,重寫(xiě)Ajax方法的代價(jià)太高,仍然可以利用jQuery自身的Ajax Events。
Ajax觸發(fā)的全局事件會(huì)像一個(gè)標(biāo)準(zhǔn)事件一樣傳播到所有DOM節(jié)點(diǎn)上。層級(jí):jQuery Events > Ajax Events > 自定義Ajax事件。
實(shí)現(xiàn)
Wo = window.Wo || {};
Wo.ajax = {
spinner : $([])
,init : function() {
var $spinner = this.spinner = $('#ajax-loading');
var show = function(e) {
if(e.namespace === 'Wo') $spinner.show();
};
var hide = function(e) {
$spinner.hide();
};
$spinner.bind({
'ajaxStart.Wo' : show
,'ajaxStop.Wo' : hide
,'ajaxError.Wo' : hide
});
this.adapt(['getJSON','get','post','ajax']);
}
// 預(yù)備發(fā)送請(qǐng)求
,_prepare : function() {
this.spinner.trigger('ajaxStart.Wo');
}
// 接口批量變更
,adapt : function(fns) {
var self = this;
$.each(fns,function(i,fn) {
Wo[fn] = function() {
self._prepare();
$[fn].apply(this,arguments);
}
});
}
};
有兩種方法可以判斷出觸發(fā)的事件是否為特定的事件:
確定的命名空間。
在觸發(fā)時(shí)傳遞額外的參數(shù)給事件處理程序。
這里用事件的命名空間來(lái)進(jìn)行觸發(fā)來(lái)源的判斷。adapt方法相當(dāng)于適配器的應(yīng)用,用一套改善的接口替代了另一套接口。
如果要增加load方法,稍微麻煩一點(diǎn),因?yàn)橛锌赡苁莂jax方法或者元素的onload事件。
要添加一個(gè)代理方法,并進(jìn)行類(lèi)型判斷:
var _load = $.fn.load;
$.fn.load = function() {
$.type(arguments[0]) === 'string' && self._prepare();
_load.apply(this,arguments);
return this;
};
使用
所有方法參數(shù)仍與原先一致:
Wo.post(url, [data,] callback)
如何在特定的請(qǐng)求上實(shí)現(xiàn)"ajaxStart"的效果?
首先,重寫(xiě)Ajax方法的代價(jià)太高,仍然可以利用jQuery自身的Ajax Events。
Ajax觸發(fā)的全局事件會(huì)像一個(gè)標(biāo)準(zhǔn)事件一樣傳播到所有DOM節(jié)點(diǎn)上。層級(jí):jQuery Events > Ajax Events > 自定義Ajax事件。
實(shí)現(xiàn)
復(fù)制代碼 代碼如下:
Wo = window.Wo || {};
Wo.ajax = {
spinner : $([])
,init : function() {
var $spinner = this.spinner = $('#ajax-loading');
var show = function(e) {
if(e.namespace === 'Wo') $spinner.show();
};
var hide = function(e) {
$spinner.hide();
};
$spinner.bind({
'ajaxStart.Wo' : show
,'ajaxStop.Wo' : hide
,'ajaxError.Wo' : hide
});
this.adapt(['getJSON','get','post','ajax']);
}
// 預(yù)備發(fā)送請(qǐng)求
,_prepare : function() {
this.spinner.trigger('ajaxStart.Wo');
}
// 接口批量變更
,adapt : function(fns) {
var self = this;
$.each(fns,function(i,fn) {
Wo[fn] = function() {
self._prepare();
$[fn].apply(this,arguments);
}
});
}
};
有兩種方法可以判斷出觸發(fā)的事件是否為特定的事件:
確定的命名空間。
在觸發(fā)時(shí)傳遞額外的參數(shù)給事件處理程序。
這里用事件的命名空間來(lái)進(jìn)行觸發(fā)來(lái)源的判斷。adapt方法相當(dāng)于適配器的應(yīng)用,用一套改善的接口替代了另一套接口。
如果要增加load方法,稍微麻煩一點(diǎn),因?yàn)橛锌赡苁莂jax方法或者元素的onload事件。
要添加一個(gè)代理方法,并進(jìn)行類(lèi)型判斷:
復(fù)制代碼 代碼如下:
var _load = $.fn.load;
$.fn.load = function() {
$.type(arguments[0]) === 'string' && self._prepare();
_load.apply(this,arguments);
return this;
};
使用
所有方法參數(shù)仍與原先一致:
復(fù)制代碼 代碼如下:
Wo.post(url, [data,] callback)
您可能感興趣的文章:
- jquery ajax請(qǐng)求方式與提示用戶(hù)正在處理請(qǐng)稍等
- php+ajax做仿百度搜索下拉自動(dòng)提示框(有實(shí)例)
- ajax 自動(dòng)完成下拉框 自動(dòng)提示位置問(wèn)題
- asp+ajax仿google搜索提示效果代碼
- jquery+ajax+text文本框?qū)崿F(xiàn)智能提示完整實(shí)例
- jquery實(shí)現(xiàn)ajax加載超時(shí)提示的方法
- Ajax實(shí)現(xiàn)智能提示搜索功能
- Ajax帶提示的驗(yàn)證表單實(shí)例
- jquery formValidator插件ajax驗(yàn)證 內(nèi)容不做任何修改再離開(kāi)提示錯(cuò)誤的bug解決方法
- ajax實(shí)現(xiàn)輸入提示效果
相關(guān)文章
jquery實(shí)現(xiàn)隱藏在左側(cè)的彈性彈出菜單效果
這篇文章主要介紹了jquery實(shí)現(xiàn)隱藏在左側(cè)的彈性彈出菜單效果,涉及jQuery動(dòng)態(tài)操作頁(yè)面元素的顯示及隱藏技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-09-09查看源碼的工具 學(xué)習(xí)jQuery源碼不錯(cuò)的工具
jQuery是一個(gè)非常好用的javascript框架,我尤其喜歡它強(qiáng)大的選擇器和鏈?zhǔn)奖磉_(dá)式,使得我們能通過(guò)簡(jiǎn)單的語(yǔ)句實(shí)現(xiàn)復(fù)雜的功能。它還有一個(gè)重要的特點(diǎn)就是它的可擴(kuò)展性,使得很多人都可以開(kāi)發(fā)他們的插件并且分享出來(lái)2011-12-12jQuery實(shí)現(xiàn)多張圖片上傳預(yù)覽(不經(jīng)過(guò)后端處理)
本篇文章主要介紹了jQuery實(shí)現(xiàn)多張圖片上傳預(yù)覽(不經(jīng)過(guò)后端處理)的相關(guān)知識(shí)。具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧2017-04-04jQuery 常見(jiàn)開(kāi)發(fā)使用技巧總結(jié)
下面這些知識(shí)都是開(kāi)發(fā)過(guò)程中,經(jīng)常遇到的。所以整理了下,需要的朋友可以參考下。2009-12-12解決用jquery load加載頁(yè)面到div時(shí),不執(zhí)行頁(yè)面js的問(wèn)題
這篇文章主要介紹了解決用jquery load加載頁(yè)面到div時(shí),不執(zhí)行頁(yè)面js的問(wèn)題。需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-02-02jquery cookie實(shí)現(xiàn)的簡(jiǎn)單換膚功能適合小網(wǎng)站
使用jquery cookie做了一個(gè)簡(jiǎn)單的換膚功能適合小網(wǎng)站并且代碼低級(jí),具體實(shí)現(xiàn)過(guò)程如下,感興趣的朋友可以了解下2013-08-08