Ajax处理服务器返回的Text/HTML、XML与JSON数据
12 浏览量
更新于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通信机制,实现与服务器的有效交互。
2732 浏览量
2507 浏览量
132 浏览量
137 浏览量
141 浏览量
183 浏览量
170 浏览量
117 浏览量
2023-11-29 上传

weixin_38644780
- 粉丝: 3
最新资源
- 易语言开发ASP空间邮件收信功能源码
- 汽车领域按键模块化编程与ISO26262功能安全标准
- nodegit-archive: 利用nodegit实现Git存档流管理
- MiF Vertretungsplan-crx插件:弗伦斯堡学校功能扩展
- MATLAB实现SVM算法的简洁指南
- 通过加速度计传感器,制作奶茶同时创造音乐
- Mahout运行环境搭建:最新基础依赖包介绍
- Swift实现3D轮播图教程及代码下载
- 式神猎手:阴阳师妖怪搜索微信小程序指南
- Hbb网络项目:网上银行平台开发解析
- Focus Shift GmbH登陆页面构建与优化实践
- Shop Direct健身房课程在线预订插件
- iOS唱吧风格背景动画实现教程
- 打造学术魅力:Latex Beamer演示文稿模板
- Linux系统MongoDB软件包下载,安全无毒,学习友好
- Rastaban:数字延时微型显微镜集焦点控制与加热功能于一体