簡潔Ajax函數(shù)處理(示例代碼)
以下是封裝的一個處理函數(shù),使用是也十分方便:
文件的名字命名為: jQuery.ajaxRequest.js .
使用方法:
$('._ajax').click(function(){
_ajax.request(this);
return false;
});
var _ajax = {
request: function(o){
var tform = $(o).parents('form');
_ar2(tform,'','_ajax._fb_request');
},
_fb._request: function(d){
d = eval('(' +unescape(d)+ ')'); //提交狀態(tài)提示。
if(d.notification){
if(d.type == 'ok'){
alert('提交成功');
}else if(d.type == 'error'){
alert('提交失敗');
}else{
alert('錯誤');
}
}
}
}
該ajax文件代碼:
// 改進版 _ar
function _ar2(s, target, feedback, param, methods){
var url, method;
var params = {};
if( (s instanceof jQuery) && s.attr("tagName")=='VFORM') {
url = s.attr('action');
method = s.attr('method');
params = param || $('input, textarea, select',s).serialize();
}else if( (s instanceof jQuery) && s.attr("tagName")=='FORM') {
url = s.attr('action');
method = s.attr('method');
params = param || s.serialize();
}else if(typeof(s)=='string'){
url = s; // http://...
}
url = url || '';
method = method || methods || 'GET';
params = param ? param : params;
jQuery.ajax({
type: method,url:url,data:params,
beforeSend: function(){
//jQuery.jGrowl('數(shù)據(jù)讀取中 請稍候..', { header: '提示', theme: 'blue'});
},
success: function(data) {
//data = jQuery.trim(data).replace(/[\n\t\r]/gi,'');
if(feedback){
eval(feedback+'(\''+escape(data)+'\')');
return;
}else{
if(data){
if(target){
jQuery(target).html(data);
jQuery.jGrowl('頁面請求完畢.', { header: '提示', theme: 'green', 'life': 100});
return;
}
}else{
lg('no feedback');
jQuery.jGrowl('服務器無返回信息.', { header: '提示', theme: 'blue'});
return;
}
}
jQuery.jGrowl(data, { header: '提示', theme: 'blue'});
},
error: function (e){
var s = e.status;
switch(s) {
case 404:
jQuery.jGrowl('請求的頁面無法找到. 請聯(lián)系系統(tǒng)管理員.', { header: '提示', theme: 'blue'});
break;
case 500:
jQuery.jGrowl('服務器錯誤[500]. 請聯(lián)系系統(tǒng)管理員.', { header: '提示', theme: 'blue'});
break;
default:
//log('unknow error');
lg(s);
jQuery.jGrowl('未知錯誤. 請聯(lián)系系統(tǒng)管理員.', { header: '提示', theme: 'blue'});
}
}
});
}
注意:jQuery.jGrowl是jquery的一個彈窗提示的插件,提示完成自動消失,用起來很方便,google一下就知道了。另外至于使用方法,返回數(shù)據(jù)是我們公司約定好的一個格式,方便使用而已。
相關文章
js/jquery獲取瀏覽器窗口可視區(qū)域高度和寬度以及滾動條高度實現(xiàn)代碼
在js使用過程中可能會根據(jù)要求獲取瀏覽器窗口的可視區(qū)域高度和寬度,滾動條高度,于是本人搜集整理下,拿出來和大家分享,希望可以幫助你們2012-12-12

