主頁 > 知識庫 > Ajax 對象 包含post和get兩種異步傳輸方式

Ajax 對象 包含post和get兩種異步傳輸方式

熱門標(biāo)簽:電銷機(jī)器人適用范圍 蓄意標(biāo)記地圖標(biāo)注 廣西ai語音電銷機(jī)器人哪家好 莆田防封電銷卡價(jià)格 信貸電銷機(jī)器人有用嗎 接聽電話機(jī)器人哪有 如何用地圖標(biāo)注各分公司 察縣地圖標(biāo)注 辦理一個(gè)400電話多少錢
復(fù)制代碼 代碼如下:

/**
* @author Supersha
* @QQ:770104121
*/
!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
html>
head>
meta http-equiv="Content-Type" content="text/html; charset=utf-8">
title>Ajax Document/title>
script type="text/javascript">
//注意,編碼要同意為utf-8才能避免中文參數(shù)和返回中文的亂碼問題
function Ajax(prop){
this.action(prop); //在實(shí)例化的時(shí)候就調(diào)用action方法
}
Ajax.prototype = {
createXHR: function(){ //創(chuàng)建XMLHttpRequest對象
var xhr = false;
if (window.XMLHttpRequest) {
xhr = new XMLHttpRequest();
}
else
if (window.ActiveXObject) {
try {
xhr = new ActiveXObject("Msxml2.XMLHTTP");
}
catch (e) {
xhr = new ActiveXObject("Microsoft.XMLHTTP");
}
}
return xhr;
},
action: function(prop){
var xhr = this.createXHR();
if (xhr) {
var url = encodeURI(prop["url"]); //對URL進(jìn)行編碼
if (prop["method"] == "GET" url prop["success"]) { //GET方法
xhr.onreadystatechange = function(){
(function(){ //自執(zhí)行函數(shù)用于檢查服務(wù)器的返回狀態(tài)并執(zhí)行回調(diào)函數(shù)
if (xhr.readyState == 4 xhr.status == 200) {
prop["success"](xhr); //執(zhí)行回調(diào)函數(shù)
}
})();
};
//alert(prop["hander"] instanceof Function);
xhr.open("GET", url, true);
xhr.send(null);
}
else
if (prop["method"] == "POST" url prop["success"]) { //POST方法
xhr.onreadystatechange = function(){
(function(){
if (xhr.readyState == 4 xhr.status == 200) {
prop["success"](xhr); //執(zhí)行回調(diào)函數(shù)
}
})();
};
if (prop["params"]) {
url = url.indexOf("?") > -1 ? url + "" + prop["params"] : url +"?" + prop["params"];
}
xhr.open("POST", url, true);
xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
xhr.send(null);
}
}
else
if (!xhr prop["fail"]) {
prop["fail"]();
}
}
}
function getData(){
var ajax = new Ajax({
url: "test.php",
method: "POST",
success: onComplete,
params: "name="+escape("沙鋒") //進(jìn)行編碼
});
}
function onComplete(obj){
alert(unescape(obj.responseText)); //進(jìn)行轉(zhuǎn)碼
}
/script>
/head>
body>
input type="button" value="Get Data" onclick="getData()"/>
/body>
/html>

注釋:
Ajax對象接受一個(gè)對象字面量為參數(shù),這個(gè)對象字面量中包含method,url,success,params,fail參數(shù)
method:"GET"或者"POST"
url:服務(wù)器端文件路徑
success:當(dāng)請求沒有錯(cuò)誤的時(shí)候,調(diào)用的回調(diào)函數(shù),該回調(diào)函數(shù)帶一個(gè)XMLHttpRequest對象的參數(shù)
fail:當(dāng)請求錯(cuò)誤的時(shí)候調(diào)用
params:當(dāng)使用POST方法發(fā)送請求是,params為參數(shù)字符串
您可能感興趣的文章:
  • JQuery中使用ajax傳輸超大數(shù)據(jù)的解決方法
  • AJAX 異步傳輸數(shù)據(jù)的問題
  • Ajax實(shí)現(xiàn)的異步傳輸與驗(yàn)證示例代碼
  • Ajax異步傳輸與PHP實(shí)現(xiàn)交互示例
  • Ajax同步與異步傳輸?shù)氖纠a
  • 利用ThinkPHP內(nèi)置的ThinkAjax實(shí)現(xiàn)異步傳輸技術(shù)的實(shí)現(xiàn)方法
  • AJAX在GB2312的中文編碼傳輸 AJAX特殊字符編碼正確方法
  • ajax數(shù)據(jù)傳輸方式實(shí)例詳解

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Ajax 對象 包含post和get兩種異步傳輸方式》,本文關(guān)鍵詞  Ajax,對象,包含,post,和,get,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Ajax 對象 包含post和get兩種異步傳輸方式》相關(guān)的同類信息!
  • 本頁收集關(guān)于Ajax 對象 包含post和get兩種異步傳輸方式的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章