Ajax处理服务器返回的Text/HTML、XML与JSON数据
146 浏览量
更新于2024-09-05
收藏 60KB PDF 举报
本文主要介绍了如何使用Ajax处理服务器返回的三种不同数据类型,包括Text/HTML格式、XML格式以及JSON格式。通过示例代码详细解释了处理这些数据的方法。
在Web开发中,Ajax(Asynchronous JavaScript and XML)是一种用于创建快速、动态网页的技术。它允许在不重新加载整个页面的情况下,与服务器交换数据并更新部分网页内容。在Ajax中,处理服务器返回的数据是关键步骤之一,根据不同的数据类型,处理方式会有所不同。
1. Text/HTML格式
这种数据类型是最常见的,服务器返回的内容通常可以直接作为字符串处理。文中提供了一个`ajaxText`函数的示例,该函数接受URL、Json数据和一个回调函数作为参数。它创建了一个XMLHttpRequest对象(或者对于旧版本的IE,创建ActiveXObject),然后以POST方式发送数据到指定URL。当服务器响应且状态码为200时,会调用回调函数`getMsg`,将接收到的文本数据作为参数传递。
```javascript
function ajaxText(url, jsonData, getMsg) {
var oAjax = window.XMLHttpRequest ? new XMLHttpRequest() : new ActiveXObject("Microsoft.XMLHTTP");
oAjax.open('POST', url, true);
var data = '';
for (var d in jsonData) {
data += (d + '=' + jsonData[d] + '&');
}
oAjax.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
oAjax.send(data);
oAjax.onreadystatechange = function() {
if (oAjax.readyState == 4 && oAjax.status == 200) {
if (getMsg) getMsg(oAjax.responseText);
}
};
}
```
2. XML格式
当服务器返回XML数据时,我们需要解析XML文档来获取其中的内容。在JavaScript中,可以使用`XMLHttpRequest`对象的`responseXML`属性来获取XML DOM对象。然后,可以使用DOM遍历和操作方法来提取和处理数据。
3. JSON格式
JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,它易于人阅读和编写,同时也易于机器解析和生成。在JavaScript中,可以使用`JSON.parse()`方法将接收到的JSON字符串转换为JavaScript对象,便于操作。例如:
```javascript
function ajaxJson(url, jsonData, getMsg) {
var oAjax = new XMLHttpRequest();
oAjax.open('POST', url, true);
oAjax.setRequestHeader("Content-type", "application/json");
oAjax.send(JSON.stringify(jsonData));
oAjax.onreadystatechange = function() {
if (oAjax.readyState == 4 && oAjax.status == 200) {
var response = JSON.parse(oAjax.responseText);
if (getMsg) getMsg(response);
}
};
}
```
服务器端在返回不同数据类型时,需要设置合适的Content-Type头部。对于XML,应设置为`text/xml;charset=utf-8`;对于Text/HTML或JSON,应设置为`text/html;charset=utf-8`。同时,为了避免浏览器缓存数据,通常还会添加`Cache-Control:no-cache`头部。
总结,处理Ajax返回的数据时,关键是根据数据类型选择正确的解析方法。Text/HTML可以直接作为字符串处理,XML需要解析DOM,而JSON则需要转换为JavaScript对象。通过合理的封装,可以构建灵活的Ajax通信机制,实现与服务器的有效交互。
2723 浏览量
2502 浏览量
116 浏览量
点击了解资源详情
167 浏览量
240 浏览量
2020-10-27 上传
152 浏览量
482 浏览量
weixin_38644780
- 粉丝: 2
最新资源
- Spring+Struts2+iBatis:轻量级框架详解,重点剖析iBatis配置与运行流程
- MATLAB基础教程:常用数学与三角函数解析
- CSS命名规范详解:打造整洁规范的代码
- 1X移动台测试规范:详细技术与性能要求
- Visual C++ MFC 异常处理与调试宏解析
- Ibatis入门与误区解析:面向对象与自由度
- 基于8086微处理器的汽车信号灯控制系统设计
- MFC应用:获取各类指针的技巧总结
- ASP.NET开发经验:配置IIS与解决Oracle错误
- C8051F系列全速USB微控制器中文资料详解
- Windows应用程序设计:从API到MFC与模式详解
- Visual C++ MFC入门:构建Windows应用
- UML在虚拟商品交易系统中的分析设计
- 汇编语言进制转换与补码计算解析
- WebService商品推荐系统:SmartRecommendation模型研究
- ADO.NET分页查询示例 - 微软技术文档