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 相关文章推荐
JavaScript mapreduce工作原理简析
Nov 25 Javascript
基于JQuery的列表拖动排序实现代码
Oct 01 Javascript
js判断设备是否为PC并调整图片大小
Feb 12 Javascript
使用jQuery的attr方法来修改onclick值
Jul 07 Javascript
jquery取子节点及当前节点属性值的方法
Sep 09 Javascript
js点击按钮实现带遮罩层的弹出视频效果
Dec 19 Javascript
jQuery表格插件datatables用法详解
Nov 23 Javascript
使用Bootstrap框架制作查询页面的界面实例代码
May 27 Javascript
jquery实现界面无刷新加载登陆注册
Jul 30 Javascript
浅谈JS中的反柯里化( uncurrying)
Aug 17 Javascript
浅谈JavaScript的innerWidth与innerHeight
Oct 12 Javascript
vuex存值与取值的实例
Nov 06 Javascript
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伪造referer突破网盘禁止外连的代码
2008/06/15 PHP
php 验证码实例代码
2010/06/01 PHP
PHPWind与Discuz截取字符函数substrs与cutstr性能比较
2011/12/05 PHP
PHP文章采集URL补全函数(FormatUrl)
2012/08/02 PHP
php简单操作mysql数据库的类
2015/04/16 PHP
PHP中的类型约束介绍
2015/05/11 PHP
jquery关于页面焦点的定位(文本框获取焦点时改变样式 )
2010/09/10 Javascript
jQuery中的.bind()、.live()和.delegate()之间区别分析
2011/06/08 Javascript
JavaScript中的标签语句用法分析
2015/02/10 Javascript
JavaScript获取页面中表单(form)数量的方法
2015/04/03 Javascript
javascript转换静态图片,增加粒子动画效果
2015/05/28 Javascript
JS中改变this指向的方法(call和apply、bind)
2016/03/26 Javascript
webpack独立打包和缓存处理详解
2017/04/03 Javascript
vue开发调试神器vue-devtools使用详解
2017/07/13 Javascript
利用nginx + node在阿里云部署https的步骤详解
2017/12/19 Javascript
Python做文本按行去重的实现方法
2016/10/19 Python
Ubuntu 16.04 LTS中源码安装Python 3.6.0的方法教程
2016/12/27 Python
Python原始字符串与Unicode字符串操作符用法实例分析
2017/07/22 Python
Python将多个excel表格合并为一个表格
2021/02/22 Python
Python3.6通过自带的urllib通过get或post方法请求url的实例
2018/05/10 Python
Python Selenium 之数据驱动测试的实现
2019/08/01 Python
Python使用scrapy爬取阳光热线问政平台过程解析
2019/08/14 Python
python软件都是免费的吗
2020/06/18 Python
Python基于callable函数检测对象是否可被调用
2020/10/16 Python
html5 localStorage本地存储_动力节点Java学院整理
2017/07/06 HTML / CSS
HTML5如何为形状图上颜色怎么绘制具有颜色和透明度的矩形
2014/06/23 HTML / CSS
毕业生个人的自我评价优秀范文
2013/10/03 职场文书
秋季运动会表扬稿
2014/01/16 职场文书
弘扬雷锋精神活动演讲稿
2014/03/04 职场文书
关于雷锋的演讲稿
2014/05/10 职场文书
2014年秋季开学典礼致辞
2014/08/02 职场文书
商务代表岗位职责
2015/02/15 职场文书
2015年公务员个人工作总结
2015/04/24 职场文书
你为什么是穷人?可能是这5个缺点造成
2019/07/11 职场文书
Spring Boot DevTools 全局配置学习指南
2022/03/31 Java/Android