婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識(shí)庫 > 自己動(dòng)手封裝的 ajax

自己動(dòng)手封裝的 ajax

熱門標(biāo)簽:察縣地圖標(biāo)注 廣西ai語音電銷機(jī)器人哪家好 電銷機(jī)器人適用范圍 如何用地圖標(biāo)注各分公司 接聽電話機(jī)器人哪有 莆田防封電銷卡價(jià)格 蓄意標(biāo)記地圖標(biāo)注 辦理一個(gè)400電話多少錢 信貸電銷機(jī)器人有用嗎
以前開發(fā)用了很多AJAX的技術(shù)比如EXT,prototype,jQuery等等,但都是開源封裝好的AJAX框架。從沒真正用過純正的AJAX,故參照prototyp面向?qū)ο笏枷胱约悍庋b了一個(gè)AJAX框架。希望能給讀者參考、幫助、評(píng)價(jià)。
復(fù)制代碼 代碼如下:

/*
* 自己封裝的ajax
*
*
* @author 姜松
* @version 1.00 $date:2009-07-02
*
* history:
*
*/
Object.extend = function(destination, source) {
for (var property in source) {
destination[property] = source[property];
}
return destination;
};
Object.extend(String.prototype, {
include: function(pattern) {
return this.indexOf(pattern) > -1;
},
startsWith: function(pattern) {
return this.indexOf(pattern) == 0;
},
endsWith: function(pattern) {
return this.lastIndexOf(pattern) == (this.length - pattern.length);
},
empty: function() {
return /^\s*$/.test(this) || this == undefined || this == null;
}
});
Object.extend(Array.prototype, {
each: function(iterator) {
try {
for (var i = 0, length = this.length; i length; i++) {
iterator(this[i]);
}
} catch (e) {
if (e != 'break') { throw e };
}
},
clear: function() {
this.length = 0;
return this;
},
first: function() {
return this[0];
},
last: function() {
return this[this.length - 1];
},
indexOf: function(object) {
for (var i = 0, length = this.length; i length; i++) {
if (this[i] == object) {return i};
}
return -1;
},
size: function() {
return this.length;
},
include: function(object) {
var found = false;
this.each(function(value) {
if (value == object) {found = true; throw 'break';}
});
return found;
}
});
function $(element) {
if(arguments.length > 1) {
for(var i = 0, elements = [], length = arguments.length; i length; i++) {
elements.push($(arguments[i]));
}
return elements;
}
if(typeof element == 'string') {
element = document.getElementById(element);
}
return element;
};
var ajax = {
transport: new Object(),
options: new Object(),
getTransport: function() {
if(window.ActiveXObject) {
try {
return new ActiveXObject('Msxm12.XMLHTTP');
} catch(e) {
try {
return new ActiveXObject('Microsoft.XMLHTTP');
} catch(e) {}
}
} else if(window.XMLHttpRequest) {
try {
return new XMLHttpRequest();
} catch(e) {}
}
},
setOptions: function(options) {
ajax.options = {
method: 'get',
asynchronous: true,
contentType: 'application/x-www-form-urlencoded',
encoding: 'utf-8',
parameters: ''
};
Object.extend(ajax.options, options);
ajax.options.method = ajax.options.method.toUpperCase();
},
request: function(url, options) {
ajax.transport = ajax.getTransport();
ajax.setOptions(options);
this.method = ajax.options.method;
var params = ajax.options.parameters;
if (!['GET', 'POST'].include(this.method)) {
this.method = 'GET';
}
if (this.method == 'GET') {
url = ajax.setParameters(url, params);
}
try {
ajax.transport.open(this.method, url, ajax.options.asynchronous);
ajax.transport.onreadystatechange = ajax.stateChange;
ajax.setRequestHeaders();
this.body = this.method == 'POST' ? params : null;
ajax.transport.send(this.body);
} catch (e) {}
},
stateChange: function() {
try {
var readyState = ajax.transport.readyState;
if(readyState == 4) {
var status = ajax.transport.status, transport = ajax, json = ajax.evalJSON();
if(status == 200) {
ajax.options['onSuccess'](transport, json);
} else {
ajax.options['onFailure'](transport, json);
}
}
} catch (e) {}
},
setParameters: function(url, params) {
if (params typeof params == 'string') {
url += (url.include('?') ? '' : '?') + params;
} else if (params typeof params == 'object') {
for(var param in params) {
url += (url.include('?') ? '' : '?') + param + '=' + params[param];
}
}
return url;
},
setRequestHeaders: function() {
var headers = {
'X-Requested-With': 'XMLHttpRequest',
'Accept': 'application/xml, text/xml, text/html, text/javascript, application/javascript, application/json, text/javascript, text/plain, */*',
'If-Modified-Since': 'Thu, 01 Jan 1970 00:00:00 GMT'
};
this.method = ajax.options.method;
if (this.method == 'POST') {
headers['Content-type'] = ajax.options.contentType +
(ajax.options.encoding ? '; charset=' + ajax.options.encoding : '');
if (ajax.transport.overrideMimeType
(navigator.userAgent.match(/Gecko\/(\d{4})/) || [0,2005])[1] 2005) {
headers['Connection'] = 'close';
}
}
for (var name in headers) {
ajax.transport.setRequestHeader(name, headers[name]);
}
},
evalJSON: function() {
try {
return eval('(' + ajax.transport.responseText + ')');
} catch (e) {}
}
};
var Form = {
serialize: function(element) {
var elements = $(element).all;
var queryComponents = [];
for(var i = 0; i elements.length; i++) {
var parameter = null, method = elements[i].tagName.toLowerCase();
if(['input', 'select', 'textarea'].include(method)) {
parameter = Form.Serializers[method](elements[i]);
}
if(parameter != null parameter.constructor == Array) {
var key = encodeURIComponent(parameter[0]);
var value = encodeURIComponent(parameter[1]);
queryComponents.push(key + '=' + value);
}
}
return queryComponents.join('');
},
request: function(options) {
var params = this.toQueryParams(options.parameters);
options.parameters = this.serialize(this.form);
if(params) {
options.parameters = options.parameters.concat('' + params);
}
if($(this.form).method) {
options.method = $(this.form).method;
}
return new ajax.request($(this.form).action, options);
},
toQueryParams: function(params) {
var queryComponents = [];
if (params typeof params == 'string') {
queryComponents.push(encodeURIComponent(params));
} else if (params typeof params == 'object') {
for(var param in params) {
var key = encodeURIComponent(param);
var value = encodeURIComponent(params[param]);
queryComponents.push(key + '=' + value);
}
}
return queryComponents.join('');
}
};
Form.Serializers = {
input: function(element) {
switch(element.type.toLowerCase()) {
case 'checkbox':
case 'radio':
return this.inputSelector(element);
default:
return this.textarea(element);
}
},
inputSelector: function(element) {
if(element.checked) {
return [element.name, element.value];
}
},
textarea: function(element) {
return [element.name, element.value];
},
select: function(element) {
return this[element.type == 'select-one' ?
'selectOne' : 'selectMany'](element);
},
selectOne: function(element) {
var value = null, option, index = element.selectedIndex;
if(index >= 0) {
option = element.options[index];
value = option.value == (undefined || '') ? option.text : option.value;
}
return [element.name, value];
},
selectMany: function(element) {
var value = [];
for(var i = 0; i element.length; i++) {
var option = element.options[i];
if(option.selected) {
var optvalue = option.value == (undefined || '') ? option.text : option.value;
value.push(optvalue);
}
}
return [element.name, value];
}
};
function $F(element) {
this.form = element;
}
Object.extend($F.prototype, Form);
/**************************************************************
* 測試函數(shù)
*/
function onTest() {
//get提交方法
var params = new Object();
params.ss = '張三';
new ajax.request('ajax.do?method=doGet', {
onSuccess: function(transport) {
alert(transport.evalJSON().xx)
},
parameters: params
});
//post form提交方法
var params = new Object();
params.idd = 1000;
params.names = '張三'
new $F('form').request({
onSuccess: function(transport) {
alert(transport.evalJSON().xx);
},
parameters: params
});
}
您可能感興趣的文章:
  • ajax的工作原理以及異步請(qǐng)求的封裝介紹
  • js原生Ajax的封裝和原理詳解
  • 基于jQuery的ajax方法封裝
  • 原生Javascript封裝的一個(gè)AJAX函數(shù)分享
  • 封裝了jQuery的Ajax請(qǐng)求全局配置
  • 一個(gè)封裝的Ajax類
  • 關(guān)于Ajax的原理以及代碼封裝詳解

標(biāo)簽:益陽 延邊 鷹潭 張掖 阿拉善盟 銅陵 儋州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《自己動(dòng)手封裝的 ajax》,本文關(guān)鍵詞  自己,動(dòng)手,封,裝的,ajax,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《自己動(dòng)手封裝的 ajax》相關(guān)的同類信息!
  • 本頁收集關(guān)于自己動(dòng)手封裝的 ajax的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    成人一区二区三区视频 | 一本色道久久综合精品竹菊| 正在播放亚洲一区| 一区二区三区视频在线看| 99国产精品一区| 亚洲黄色性网站| 在线视频你懂得一区| 亚洲精品中文字幕乱码三区| 日本国产一区二区| 日韩电影在线一区| 久久色在线视频| 成人国产精品免费观看视频| 亚洲色图一区二区三区| 欧美日韩亚洲国产综合| 美腿丝袜一区二区三区| 久久先锋影音av| 国产成人免费视频| 一个色在线综合| 2020日本不卡一区二区视频| av亚洲精华国产精华精| 日韩成人av影视| 久久精品一二三| 成人丝袜18视频在线观看| 亚洲一区免费在线观看| 欧美tickling网站挠脚心| www.日韩在线| 亚洲精品你懂的| 7777精品久久久大香线蕉| 亚洲视频免费在线| 一区二区三区不卡视频| 日韩一级免费观看| 国产成人av电影| 人人爽香蕉精品| 国产视频一区二区在线| 黄色成人免费在线| 国产精品二三区| 国产精品免费视频一区| 亚洲欧美一区二区在线观看| 国产精品国产馆在线真实露脸 | 欧美日精品一区视频| 337p粉嫩大胆噜噜噜噜噜91av| 国产精品久久久久影院亚瑟| 亚洲人成网站在线| 日本美女视频一区二区| 91天堂素人约啪| 精品日韩在线观看| 久久久综合精品| 国产成人在线看| 亚洲成人中文在线| 精品少妇一区二区三区视频免付费 | 91小视频在线| 国产精品自在欧美一区| 洋洋av久久久久久久一区| 日韩写真欧美这视频| 成人综合婷婷国产精品久久| 日韩和的一区二区| 欧美日本在线一区| 成人美女视频在线看| 日av在线不卡| 夜夜亚洲天天久久| 亚洲欧洲av另类| 国产校园另类小说区| 欧洲av一区二区嗯嗯嗯啊| 久久99精品一区二区三区三区| 青青草伊人久久| 久久99精品久久久久久动态图| 免费的成人av| 国产一区二区三区久久久| 日韩久久一区二区| 国产精品成人免费 | 高清不卡一区二区在线| 热久久免费视频| 奇米色一区二区| 亚洲美女屁股眼交3| 亚洲制服丝袜av| 亚洲成人免费在线观看| 国产一区二区美女| 亚洲精选在线视频| 亚洲日本韩国一区| 亚洲色图欧美偷拍| 亚洲精品视频在线观看免费 | 久久久久久久久久美女| 精品蜜桃在线看| 国产日韩欧美精品一区| 国产女人aaa级久久久级| 国产午夜精品一区二区| 国产精品成人免费在线| 亚洲免费观看视频| 亚洲国产美国国产综合一区二区| 亚洲福利视频三区| 日韩中文欧美在线| 国产高清不卡一区| 欧美性大战久久久久久久蜜臀| 日韩三级免费观看| 精品在线观看视频| 91黄视频在线观看| 精品少妇一区二区三区视频免付费| 免费亚洲电影在线| 国产精品网站一区| 欧美日韩你懂得| 日本视频中文字幕一区二区三区| 91精品国产综合久久蜜臀| 蜜桃av一区二区在线观看| 精品久久99ma| 欧美日韩一区 二区 三区 久久精品| 一区二区在线电影| 国产午夜精品久久| 色婷婷香蕉在线一区二区| 亚洲成人一二三| 免费成人性网站| 美女一区二区三区在线观看| 欧美日韩一区二区在线视频| 日韩一级片网址| 中文字幕第一区第二区| 午夜电影久久久| zzijzzij亚洲日本少妇熟睡| 日韩免费一区二区| 亚洲在线一区二区三区| 91蜜桃免费观看视频| 日韩你懂的在线播放| 一区二区三区91| 99久久综合国产精品| 久久久久久麻豆| 青草av.久久免费一区| 欧美在线观看一区| 最新国产精品久久精品| 成人黄色777网| 久久久久久久久蜜桃| 国内精品在线播放| 精品国产青草久久久久福利| 日韩一区欧美二区| 5858s免费视频成人| 三级欧美在线一区| 欧美亚一区二区| 亚洲免费观看高清完整| 91捆绑美女网站| 亚洲精品免费视频| 欧美综合久久久| 亚洲一区二区三区精品在线| 91丝袜国产在线播放| 亚洲日本中文字幕区| 99精品视频中文字幕| 亚洲精品菠萝久久久久久久| 色婷婷激情综合| 亚洲v日本v欧美v久久精品| 欧美日韩午夜在线| 蜜桃一区二区三区在线| 精品国产免费一区二区三区香蕉| 捆绑调教一区二区三区| 欧美一二三区在线| 国产一区二区三区四| 中文字幕精品在线不卡| 国产成人亚洲综合a∨猫咪| 欧美激情综合在线| 一本色道a无线码一区v| 一二三区精品视频| 欧美一区二区三区影视| 国产在线视频不卡二| 亚洲三级理论片| 欧美电影免费观看高清完整版在线| 精品在线观看视频| 国产精品久久久久影院老司| 欧美私人免费视频| 国产在线精品免费av| 国产亚洲综合在线| 成人av网站大全| 午夜视黄欧洲亚洲| 国产人成亚洲第一网站在线播放| 91亚洲精品久久久蜜桃网站| 午夜激情一区二区| 久久久美女艺术照精彩视频福利播放 | 秋霞午夜av一区二区三区| 久久亚洲精精品中文字幕早川悠里| 久久国产精品免费| 久久久www免费人成精品| 激情深爱一区二区| 亚洲色图在线视频| 欧美女孩性生活视频| 精品系列免费在线观看| 国产精品成人一区二区艾草 | 亚洲裸体在线观看| 8x8x8国产精品| 懂色av噜噜一区二区三区av| 国产综合色产在线精品| 一区二区三区精品在线观看| 久久亚洲私人国产精品va媚药| 国产精一区二区三区| 亚洲免费在线播放| 久久久国产精华| 欧美日韩在线播放三区四区| 国产精品影音先锋| 亚洲国产精品一区二区www在线| 欧美一二三区在线观看| 91麻豆文化传媒在线观看| 国产在线精品不卡| 奇米色777欧美一区二区| 亚洲一区在线观看免费 | 亚洲色图在线视频| 国产偷国产偷精品高清尤物| 欧美区视频在线观看|