本文實(shí)例講述了ajax數(shù)據(jù)傳輸方式。分享給大家供大家參考,具體如下:
在異步應(yīng)用程序中發(fā)送和接收信息時,常見的可以選擇以純文本和XML作為數(shù)據(jù)格式(可參考《jQuery學(xué)習(xí)筆記之Ajax用法實(shí)例詳解》),現(xiàn)在還有一種比較流行的方式:JSON(JavaScript Object Notation)。好了,下面舉例說明這三種數(shù)據(jù)格式在ajax的異步應(yīng)用。
一、純文本方式
1、發(fā)送/接收數(shù)據(jù):
Code is cheap.看代碼:
testJs.js
// 此函數(shù)等價于document.getElementById /document.all
function $(s) { if (document.getElementById) { return eval('document.getElementById("' + s + '")'); } else { return eval('document.all.' + s); } }
// 創(chuàng)建 XMLHttpRequest對象,以發(fā)送ajax請求
function createXMLHTTP() {
var xmlHttp = false;
var arrSignatures = ["MSXML2.XMLHTTP.5.0", "MSXML2.XMLHTTP.4.0",
"MSXML2.XMLHTTP.3.0", "MSXML2.XMLHTTP",
"Microsoft.XMLHTTP"];
for (var i = 0; i arrSignatures.length; i++) {
try {
xmlHttp = new ActiveXObject(arrSignatures[i]);
return xmlHttp;
}
catch (oError) {
xmlHttp = false; //ignore
}
}
// throw new Error("MSXML is not installed on your system.");
if (!xmlHttp typeof XMLHttpRequest != 'undefined') {
xmlHttp = new XMLHttpRequest();
}
return xmlHttp;
}
var xmlReq = createXMLHTTP();
// 發(fā)送ajax處理請求(這里簡單驗(yàn)證用戶名和密碼的有效性,默認(rèn)正確的輸入:用戶名和密碼都是test)
function validatePwd(oTxt) {
var url = "/AjaxOperations.aspx";
xmlReq.open("post", url, true);
xmlReq.setRequestHeader("Content-Length", oTxt.value.length + $("txtUserName").value.length);
xmlReq.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xmlReq.onreadystatechange = callBack;
xmlReq.send("action=chkPwduserInfos=" + escape(oTxt.value + "/" + $("txtUserName").value)); // 發(fā)送文本
}
function callBack() {
if (xmlReq.readyState == 4) {
if (xmlReq.status == 200) {
alert(xmlReq.responseText); // 接收文本
}
else if (xmlReq.status == 404) {
alert("Requested URL is not found.");
} else if (xmlReq.status == 403) {
alert("Access denied.");
} else
alert("status is " + xmlReq.status);
}
}
幾個附加文件源碼:
jsTest.htm
html>
head>
title>js test/title>
script src="js/testJs.js" type="text/javascript">/script>
/head>
body>
form id="form1">
div>
用戶名:input id="txtUserName" name="txtUserName" type="text" /> nbsp;密碼:input id="txtPwd" name="txtPwd" type="password" onblur="validatePwd(this)" />/div>
/form>
/body>
/html>
AjaxOperations.aspx
復(fù)制代碼 代碼如下:
%@ Page Language="C#" AutoEventWireup="true" CodeBehind="AjaxOperations.aspx.cs" Inherits="WebTest2008.AjaxOperations" %>
AjaxOperations.aspx.cs
using System;
using System.Collections.Generic;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace WebTest2008
{
public partial class AjaxOperations : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!string.IsNullOrEmpty(Request["action"]) Request["action"] == "chkPwd")
{
string responseTxt = "用戶名和密碼不匹配!";
string tempStr = Request["userInfos"];
/* 測試用 實(shí)際項(xiàng)目中可以對數(shù)據(jù)庫進(jìn)行檢索等等相關(guān)操作,這里簡化了 */
if (tempStr.Split(new char[] { '/' }, StringSplitOptions.RemoveEmptyEntries)[0] == "test" tempStr.Split(new char[] { '/' }, StringSplitOptions.RemoveEmptyEntries)[1] == "test")
{
responseTxt = "驗(yàn)證通過!";
}
Response.Write(responseTxt);
}
}
}
}
一一保存文件,ctrl+F5,運(yùn)行試試看吧。
上面這種方式是最簡單最直接也是最有效的方式。熟練使用最佳。
二、XML方式
1、發(fā)送XML數(shù)據(jù)
testJs.js
// 此函數(shù)等價于document.getElementById /document.all
function $(s) { if (document.getElementById) { return eval('document.getElementById("' + s + '")'); } else { return eval('document.all.' + s); } }
// 創(chuàng)建 XMLHttpRequest對象,以發(fā)送ajax請求
function createXMLHTTP() {
var xmlHttp = false;
var arrSignatures = ["MSXML2.XMLHTTP.5.0", "MSXML2.XMLHTTP.4.0",
"MSXML2.XMLHTTP.3.0", "MSXML2.XMLHTTP",
"Microsoft.XMLHTTP"];
for (var i = 0; i arrSignatures.length; i++) {
try {
xmlHttp = new ActiveXObject(arrSignatures[i]);
return xmlHttp;
}
catch (oError) {
xmlHttp = false; //ignore
}
}
// throw new Error("MSXML is not installed on your system.");
if (!xmlHttp typeof XMLHttpRequest != 'undefined') {
xmlHttp = new XMLHttpRequest();
}
return xmlHttp;
}
var xmlReq = createXMLHTTP();
// 發(fā)送ajax處理請求(這里簡單驗(yàn)證用戶名和密碼的有效性,默認(rèn)正確的輸入:用戶名和密碼都是test)
function validatePwd(oTxt) {
var url = "/AjaxOperations.aspx?action=xmlOp";
var xmlStr = "profile>" +
" userName>" + escape($("txtUserName").value) + "/userName>" +
" userPwd>" + escape($("txtPwd").value) + "/userPwd>" +
"/profile>";
xmlReq.open("post", url, true);
// Tell the server you're sending it XML
xmlReq.setRequestHeader("Content-Type", "text/xml"); // 這里注意
xmlReq.onreadystatechange = callBack;
xmlReq.send(xmlStr); // 發(fā)送XML
}
function callBack() {
if (xmlReq.readyState == 4) {
if (xmlReq.status == 200) {
alert(xmlReq.responseText); // 接收文本
}
else if (xmlReq.status == 404) {
alert("Requested URL is not found.");
} else if (xmlReq.status == 403) {
alert("Access denied.");
} else
alert("status is " + xmlReq.status);
}
}
jsTest.htm文件不變,AjaxOperations.aspx的HTML文件內(nèi)容不變,服務(wù)器端.CS處理代碼如下:
AjaxOperations.aspx.cs
using System;
using System.Collections.Generic;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Xml;
namespace WebTest2008
{
public partial class AjaxOperations : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!string.IsNullOrEmpty(Request["action"]) Request["action"] == "xmlOp") // 處理xml
{
XmlDocument doc = new XmlDocument();
try
{
doc.Load(Request.InputStream); //獲取xml數(shù)據(jù)(這里需要注意接受xml數(shù)據(jù)的方法)
}
catch (Exception ex)
{
throw ex;
}
string responseTxt = "";
string tempName = doc.SelectSingleNode("profile/userName").InnerText;
string tempPwd = doc.SelectSingleNode("profile/userPwd").InnerText;
if (tempName == "test" tempPwd == "test")
{
responseTxt = "驗(yàn)證通過!";
}
else responseTxt = "驗(yàn)證失?。?;
Response.Write(responseTxt); // 寫文本
}
}
}
}
很簡單的代碼,運(yùn)行看看吧。
2、接收XML數(shù)據(jù):
我們看到,上面兩個.js文件里處理返回?cái)?shù)據(jù)時都用到了xmlReq.responseText的屬性,下面我們試試看xmlReq.responseXML屬性:
testJs.js
// 此函數(shù)等價于document.getElementById /document.all
function $(s) { if (document.getElementById) { return eval('document.getElementById("' + s + '")'); } else { return eval('document.all.' + s); } }
// 創(chuàng)建 XMLHttpRequest對象,以發(fā)送ajax請求
function createXMLHTTP() {
var xmlHttp = false;
var arrSignatures = ["MSXML2.XMLHTTP.5.0", "MSXML2.XMLHTTP.4.0",
"MSXML2.XMLHTTP.3.0", "MSXML2.XMLHTTP",
"Microsoft.XMLHTTP"];
for (var i = 0; i arrSignatures.length; i++) {
try {
xmlHttp = new ActiveXObject(arrSignatures[i]);
return xmlHttp;
}
catch (oError) {
xmlHttp = false; //ignore
}
}
// throw new Error("MSXML is not installed on your system.");
if (!xmlHttp typeof XMLHttpRequest != 'undefined') {
xmlHttp = new XMLHttpRequest();
}
return xmlHttp;
}
var xmlReq = createXMLHTTP();
// 發(fā)送ajax處理請求(這里簡單驗(yàn)證用戶名和密碼的有效性,默認(rèn)正確的輸入:用戶名和密碼都是test)
function validatePwd(oTxt) {
var url = "/AjaxOperations.aspx?action=xmlOp";
var xmlStr = "profile>" +
" userName>" + escape($("txtUserName").value) + "/userName>" +
" userPwd>" + escape($("txtPwd").value) + "/userPwd>" +
"/profile>";
xmlReq.open("post", url, true);
// Tell the server you're sending it XML
xmlReq.setRequestHeader("Content-Type", "text/xml");
xmlReq.onreadystatechange = callBack;
xmlReq.send(xmlStr); // 發(fā)送XML
}
function callBack() {
if (xmlReq.readyState == 4) {
if (xmlReq.status == 200) {
var xmlDoc = xmlReq.responseXML; // 接收XML
// var nodes = xmlDoc.childNodes;
// alert("文件根標(biāo)簽的名稱: " + xmlDoc.documentElement.tagName);
// alert("根元素共有子節(jié)點(diǎn)個數(shù): " + xmlDoc.documentElement.childNodes.length);
alert(xmlDoc.documentElement.childNodes(0).text);
}
else if (xmlReq.status == 404) {
alert("Requested URL is not found.");
} else if (xmlReq.status == 403) {
alert("Access denied.");
} else
alert("status is " + xmlReq.status);
}
}
同樣,jsTest.htm文件不變,AjaxOperations.aspx的HTML文件內(nèi)容不變,服務(wù)器端.CS處理代碼稍作修改如下:
using System;
using System.Collections.Generic;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Xml;
namespace WebTest2008
{
public partial class AjaxOperations : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!string.IsNullOrEmpty(Request["action"]) Request["action"] == "xmlOp") // 處理xml
{
XmlDocument doc = new XmlDocument();
try
{
doc.Load(Request.InputStream); //獲取xml數(shù)據(jù)
}
catch (Exception ex)
{
throw ex;
}
string responseXmlTxt = "";
string tempName = doc.SelectSingleNode("profile/userName").InnerText;
string tempPwd = doc.SelectSingleNode("profile/userPwd").InnerText;
if (tempName == "test" tempPwd == "test")
{
responseXmlTxt = "?xml version=\"1.0\" encoding=\"utf-8\" ?> msg>驗(yàn)證通過!/msg>"; // 測試用,簡單的xml文件
}
else responseXmlTxt = "?xml version=\"1.0\" encoding=\"utf-8\" ?>msg>驗(yàn)證失?。?msg>";
Response.ContentType = ("text/xml;charset=UTF-8"); // 這里必須要設(shè)置,否則客戶端接收不到這里寫好的xml文件
Response.Write(responseXmlTxt); // 寫xml
Response.End();
}
}
}
}
好了,前面兩種方法是大家平時開發(fā)中比較熟悉的方式,下面我們來看看第三種方式。
三、JSON方式
json的準(zhǔn)備知識:
json是一種簡單的數(shù)據(jù)格式,比xml更輕巧。json是JavaScript 的原生格式,這意味著在 JavaScript 中處理json格式的 數(shù)據(jù)不需要任何特殊的API 或工具包。json的語法規(guī)則其實(shí)很簡單:對象是一個無序的“‘名稱/值'對”集合。一個對象以“{”(左括號)開始,“}”(右括號)結(jié)束。每個“名稱”后跟一個“:”(冒號);“‘名稱/值' 對”之間使用“,”(逗號)分隔??磦€例子先:
function testJson() {
//定義一個user(json的格式,其實(shí)就是定義一個js函數(shù)(變量)的方式而已)
var user =
{
"username": "jeff wong",
"age": 25,
"info": { "tel": "12345678", "cellphone": "13312345678" },
"address": // 數(shù)組
[
{ "city": "beijing", "postcode": "101110" },
{ "city": "ny city", "postcode": "911119" }
]
}
alert(user.username);
alert(user.age);
alert(user.info.cellphone);
alert(user.address[0].city);
alert(user.address[0].postcode);
user.username = "xiao wang";
alert(user.username);
}
上面的定義方式看起來很簡單,但是如果字段眾多,命名方式混雜,出錯的概率大大增加,怎么辦?這時候你就會想到用程序的方式生成json數(shù)據(jù)。json提供了json.js包,專門提供了幾種常用的json處理函數(shù)。下載下來,(json.js點(diǎn)擊此處本站下載。) ,將其引入然后就可以簡單的使用object.toJSONString()轉(zhuǎn)換成json數(shù)據(jù)??创a:
function Car(maker, model, year, color) {
this.maker = maker;
this.model = model;
this.year = year;
this.color = color;
}
function testJson() {
var tempCar = new Car("VW", "S", 1999, "yellow");
alert(tempCar.toJSONString());
}
也可以使用eval或者parseJSON()方法來轉(zhuǎn)換json數(shù)據(jù)到object:
function testJson() {
var str = '{ "name": "jeff wong", "age": 25,"address":"beijing"}';
var tempObj = eval('(' + str + ')');
alert(tempObj.toJSONString()); //使用eval方法
var tempObj1 = str.parseJSON();
alert(tempObj1.toJSONString()); // 或者使用parseJSON()方法
}
關(guān)于json.js的學(xué)習(xí),請參考網(wǎng)上其他資源,這里我不再贅述了。說了這么多,實(shí)踐環(huán)節(jié)開始了:
ajax利用json發(fā)送/接收數(shù)據(jù):
// 此函數(shù)等價于document.getElementById /document.all
function $(s) { if (document.getElementById) { return eval('document.getElementById("' + s + '")'); } else { return eval('document.all.' + s); } }
// 創(chuàng)建 XMLHttpRequest對象,以發(fā)送ajax請求
function createXMLHTTP() {
var xmlHttp = false;
var arrSignatures = ["MSXML2.XMLHTTP.5.0", "MSXML2.XMLHTTP.4.0",
"MSXML2.XMLHTTP.3.0", "MSXML2.XMLHTTP",
"Microsoft.XMLHTTP"];
for (var i = 0; i arrSignatures.length; i++) {
try {
xmlHttp = new ActiveXObject(arrSignatures[i]);
return xmlHttp;
}
catch (oError) {
xmlHttp = false; //ignore
}
}
// throw new Error("MSXML is not installed on your system.");
if (!xmlHttp typeof XMLHttpRequest != 'undefined') {
xmlHttp = new XMLHttpRequest();
}
return xmlHttp;
}
var xmlReq = createXMLHTTP();
// 發(fā)送ajax處理請求(這里簡單驗(yàn)證用戶名和密碼的有效性,默認(rèn)正確的輸入:用戶名和密碼都是test)
function validatePwd(oTxt) {
var url = "/AjaxOperations.aspx?action=jsonOp";
// JSON就只是文本,由于不需要特殊編碼而且每個服務(wù)器端腳本都能處理文本數(shù)據(jù),所以可以輕松利用JSON并將其應(yīng)用到服務(wù)器。
var str = '{ "userName":"' + $("txtUserName").value + '", "userPwd": "' + $("txtPwd").value + '"}';
var jsonStr = str.parseJSON().toJSONString(); // you're sending it JSON
xmlReq.open("post", url, true);
xmlReq.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xmlReq.onreadystatechange = callBack;
xmlReq.send("sendStr=" + jsonStr); // 發(fā)送JSON(在服務(wù)器上解釋JSON)
}
function callBack() {
if (xmlReq.readyState == 4) {
if (xmlReq.status == 200) {
var jsonStr = xmlReq.responseText.parseJSON().toJSONString(); //轉(zhuǎn)化為json數(shù)據(jù)
alert(jsonStr);
}
else if (xmlReq.status == 404) {
alert("Requested URL is not found.");
} else if (xmlReq.status == 403) {
alert("Access denied.");
} else
alert("status is " + xmlReq.status);
}
}
附加文件,AjaxOperations.aspx的html頁面沒有改變,AjaxOperations.aspx.cs代碼稍作調(diào)整如下:
using System;
using System.Collections.Generic;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace WebTest2008
{
public partial class AjaxOperations : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!string.IsNullOrEmpty(Request["action"]) Request["action"] == "jsonOp") // 處理JSON
{
string responseJsonTxt = "";
string tempStr = Request["sendStr"].Trim(new char[] { '{', '}' }); // 在服務(wù)器上解釋JSON需要引用一個能夠轉(zhuǎn)化JSON的組件:Json.Net,這里簡單測試,略過Json.Net
if (tempStr.Split(new char[] { ',' })[0].Split(new char[] { ':' })[1] == "\"test\"" tempStr.Split(new char[] { ',' })[1].Split(new char[] { ':' })[1] == "\"test\"")
{
responseJsonTxt = "{\"msg\":\"驗(yàn)證通過!\"}"; // 測試用
}
else responseJsonTxt = "{\"msg\":\"驗(yàn)證失?。"}";
Response.Write(responseJsonTxt);
Response.End();
}
}
jsTest.html引入json.js文件(必須下載json.js文件,否則js報(bào)錯),如下:
html>
head>
title>js test/title>
script src="js/json.js" type="text/javascript">/script>
script src="js/testJs.js" type="text/javascript">/script>
/head>
body>
form id="form1">
div>
用戶名:input id="txtUserName" name="txtUserName" type="text" />
nbsp;密碼:input id="txtPwd" name="txtPwd" type="password" onblur="validatePwd(this)" />/div>
/form>
/body>
/html>
希望本文所述對大家ajax程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:- 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 對象 包含post和get兩種異步傳輸方式