jquery ajax学习笔记2 使用XMLHttpRequest对象的responseXML


Posted in Javascript onOctober 16, 2011

摘要:本节补充ajax学习笔记1中
第二种方式:使用XMLHttpRequest对象的responseXML的方式来接受XML数据对象的DOM对象
在ajax学习笔记1中已经对准备工作和需要用到的知识做了比较详细的介绍,本节主要介绍需要修改的代码以及新增的代码
.新增一个servlet类
AJAXXMLServer.java

import javax.servlet.http.HttpServlet; 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse; 
import javax.servlet.ServletException; 
import java.io.IOException; 
import java.io.PrintWriter; 
//XML的数据 
public class AJAXXMLServer extends HttpServlet { 
public void doGet(HttpServletRequest request, HttpServletResponse response) 
throws ServletException, IOException { 
//response.setContentType("text/html;charset=utf-8"); 
response.setContentType("text/xml;charset=utf-8"); //修改此次为text/xml 
PrintWriter out=response.getWriter(); 
//1.取参数 
String old=request.getParameter("name"); 
StringBuffer sb=new StringBuffer(); 
sb.append("<message>"); 
//2.检查是否有问题 
if(old==null||old.length()==0){ 
sb.append("用户名不能为空").append("</message>"); //拼装XML 
}else{ 
//3.校验操作 
String name=old; 
if(name.equals("pan")){ 
//4.和传统应用不同之处。这一步需要将用户感兴趣的数据返回给页面端,而不是将一个新的页面发送给用户 
//写法没有变,本质变了 
sb.append("用户名["+name+"]已经存在").append("</message>"); //拼装XML 
}else{ 
sb.append("用户名["+name+"]可以使用").append("</message>"); //拼装XML 
} 
} 
out.println(sb.toString());//注意,此句一定不能少了,并且注意放置的位置 
} 
public void doPost(HttpServletRequest request, HttpServletResponse response) 
throws ServletException, IOException { 
this.doGet(request,response); 
} 
}

.修改web.xml
加入AJAXXMLServer类的配置
web.xml
<servlet> 
<servlet-name>AJAXXMLServer</servlet-name> 
<servlet-class>AJAXXMLServer</servlet-class> 
</servlet> 
<servlet-mapping> 
<servlet-name>AJAXXMLServer</servlet-name> 
<url-pattern>/AJAXXMLServer</url-pattern> 
</servlet-mapping>

.修改verify.js文件
第一处:
把xmlhttp.open("GET","AJAXServer?name="+username,true);

改为
xmlhttp.open("GET","AJAXXMLServer?name="+username,true);//responseXML方式,修改类名

第二处:

responseText
//获取服务器端返回的数据 
//第一种方式:获取服务器端输出的纯文本数据 
//var responseText=xmlhttp.responseText; 
//将数据显示在页面上 通过dom的方式找到div标签对应的元素节点 
//var divNode=document.getElementById("result"); 
//设置元素节点中的html的内容 
//divNode.innerHTML=responseText;

改为:
responseXML
//第二种方式:使用responseXML的方式来接受XML数据对象的DOM对象 
var domObj = xmlhttp.responseXML; 
var messageNodes = domObj.getElementsByTagName("message"); 
//获取message节点中的文本内容 
//message标签中的文本是在dom中是message标签所对应的元素节点的子节点,firstChild可以获取当前节点的第一个子节点 
if (messageNodes.length > 0) { 
var textNode = messageNodes[0].firstChild; 
//对于文本节点来说,可以通过nodeValue的方式返回文本 
var responseMessage = textNode.nodeValue; 
//把值responseMessage显示在div上 
var divNode=document.getElementById("result"); 
divNode.innerHTML=responseMessage; 
} else { 
alert("XML数据格式错误,原始文本内容为:" + xmlhttp.responseText); 
}

第三处:

text/html
if(xmlhttp.overrideMimeType){ 
xmlhttp.overrideMimeType("text/html"); 
}

改为:
text/xml
if(xmlhttp.overrideMimeType){ 
xmlhttp.overrideMimeType("text/xml");//XML的方式时需要修改这个地方 
}

对于IE浏览器如果第三处不修改不会报错,但是对于firefox浏览器,如果此处不修改,以下语句会报错
var domObj = xmlhttp.responseXML;
可以通过增加alert语句来验证,IE浏览器的时候第三处修改的代码的if语句不会被执行,firefox浏览器的时候这个if语句就会被执行

说明:访问路径、运行截图与ajax学习笔记1中都是已经的,就省略了。

Javascript 相关文章推荐
总结一些js自定义的函数
Aug 05 Javascript
jQuery ready函数滥用分析
Feb 16 Javascript
jquery动画1.加载指示器
Aug 24 Javascript
js 实现菜单左右滚动显示示例介绍
Nov 21 Javascript
angularjs的一些优化小技巧
Dec 06 Javascript
javascript 中的 delete及delete运算符
Nov 15 Javascript
js使用cookie记录用户名的方法
Nov 26 Javascript
JavaScript登录验证码的实现
Oct 27 Javascript
Node.js使用orm2进行update操作时关联字段无法修改的解决方法
Jun 13 Javascript
React Native第三方平台分享的实例(Android,IOS双平台)
Aug 04 Javascript
详解原生JS动态添加和删除类
Mar 26 Javascript
vue 使用class创建和清除水印的示例代码
Dec 25 Vue.js
jquery中ajax学习笔记一
Oct 16 #Javascript
jQuery EasyUI API 中文文档 DateTimeBox日期时间框
Oct 16 #Javascript
自己动手制作jquery插件之自动添加删除行功能介绍
Oct 14 #Javascript
javascript nextSibling 与 getNextElement(node) 使用介绍
Oct 13 #Javascript
获取body标签的两种方法
Oct 13 #Javascript
自己动手制作jquery插件之自动添加删除行的实现
Oct 13 #Javascript
jQuery EasyUI API 中文文档 - NumberBox数字框
Oct 13 #Javascript
You might like
PHP实现简单爬虫的方法
2015/07/29 PHP
PHP代码维护,重构变困难的4种原因分析
2016/01/25 PHP
php实现微信公众平台发红包功能
2018/06/14 PHP
php ActiveMQ的安装与使用方法图文教程
2020/02/23 PHP
jQuery获取Select选择的Text和Value(详细汇总)
2013/01/25 Javascript
JavaScript等比例缩放图片控制超出范围的图片
2013/08/06 Javascript
js模拟点击以提交表单为例兼容主流浏览器
2013/11/29 Javascript
nodejs模块nodemailer基本使用-邮件发送示例(支持附件)
2017/03/28 NodeJs
vuejs实现折叠面板展开收缩动画效果
2018/09/06 Javascript
iview tabs 顶部导航栏和模块切换栏的示例代码
2019/03/04 Javascript
详解用场景去理解函数柯里化(入门篇)
2019/04/11 Javascript
js计算最大公约数和最小公倍数代码实例
2019/09/11 Javascript
JS操作字符串转数字的常见方法示例
2019/10/29 Javascript
vuex state中的数组变化监听实例
2019/11/06 Javascript
react 生命周期实例分析
2020/05/18 Javascript
vue 组件简介
2020/07/31 Javascript
vue循环中点击选中再点击取消(单选)的实现
2020/09/10 Javascript
vue实现滚动鼠标滚轮切换页面
2020/12/13 Vue.js
[47:03]完美世界DOTA2联赛PWL S3 access vs LBZS 第一场 12.20
2020/12/23 DOTA
给Python中的MySQLdb模块添加超时功能的教程
2015/05/05 Python
python简单读取大文件的方法
2016/07/01 Python
Eclipse和PyDev搭建完美Python开发环境教程(Windows篇)
2016/11/16 Python
Python程序员面试题 你必须提前准备!
2018/01/16 Python
python jieba分词并统计词频后输出结果到Excel和txt文档方法
2018/02/11 Python
Python对称的二叉树多种思路实现方法
2020/02/28 Python
YOOX美国官方网站:全球著名的多品牌时尚网络概念店
2016/09/11 全球购物
海滩咖啡馆:Beach Cafe
2018/02/02 全球购物
装潢设计实习自我鉴定
2013/09/19 职场文书
考试作弊被抓检讨书
2014/01/10 职场文书
大学军训感言300字
2014/03/09 职场文书
初三毕业评语
2014/12/26 职场文书
学期个人自我总结
2015/02/13 职场文书
正确使用MySQL update语句
2021/05/26 MySQL
vue+element ui实现锚点定位
2021/06/29 Vue.js
世界无敌的ICOM IC-R9500宽频接收机
2022/03/25 无线电
Win11显卡控制面板打开显卡设置方法
2022/04/20 数码科技