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 相关文章推荐
jquery 元素相对定位代码
Oct 15 Javascript
jquery ajax跨域解决方法(json方式)
Feb 04 Javascript
在JS中解析HTML字符串示例代码
Apr 16 Javascript
在浏览器中实现图片粘贴的jQuery插件-- pasteimg使用指南
Dec 29 Javascript
纯JavaScript实现的分页插件实例
Jul 14 Javascript
js遮罩效果制作弹出注册界面效果
Jan 25 Javascript
微信小程序 蓝牙的实现实例代码
Jun 27 Javascript
Vue学习笔记进阶篇之函数化组件解析
Jul 21 Javascript
vue用Object.defineProperty手写一个简单的双向绑定的示例
Jul 09 Javascript
JavaScript基础之this和箭头函数详析
Sep 05 Javascript
Vue3新特性之在Composition API中使用CSS Modules
Jul 13 Javascript
Vue+penlayers实现多边形绘制及展示
Dec 24 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 上传文件的方法(类)
2009/07/30 PHP
一个简单php扩展介绍与开发教程
2010/08/19 PHP
163的邮件用phpmailer发送(实例详解)
2013/06/24 PHP
phpstrom使用xdebug配置方法
2013/12/17 PHP
PHP同时连接多个mysql数据库示例代码
2014/03/17 PHP
composer.lock文件的作用
2016/02/03 PHP
thinkPHP中钩子的两种配置调用方法详解
2016/11/11 PHP
PHP实践教程之过滤、验证、转义与密码详解
2017/07/24 PHP
php 读取文件夹下所有图片、文件的实例
2018/10/17 PHP
安装PHP扩展时解压官方 tgz 文件后没有configure文件无法进行配置编译的问题
2020/08/26 PHP
JavaScript监测ActiveX控件是否已经安装过的代码
2008/09/02 Javascript
基于jquery插件实现常见的幻灯片效果
2013/11/01 Javascript
验证码在IE中不刷新而谷歌等浏览器正常的解决方案
2014/03/18 Javascript
javascript简单实现类似QQ头像弹出效果的方法
2015/08/03 Javascript
纯jquery实现模仿淘宝购物车结算
2015/08/20 Javascript
js实现select选择框效果及美化
2016/08/19 Javascript
js实现点击图片自动提交action的简单方法
2016/10/16 Javascript
关于Jquery中的事件绑定总结
2016/10/26 Javascript
微信小程序 网络API发起请求详解
2016/11/09 Javascript
ES6新特性之模块Module用法详解
2017/04/01 Javascript
windows下vue-cli及webpack搭建安装环境
2017/04/25 Javascript
javascript trie前缀树的示例
2018/01/29 Javascript
Angular ng-animate和ng-cookies用法详解
2018/04/18 Javascript
jQuery+PHP+Ajax实现动态数字统计展示功能
2019/12/25 jQuery
Python的Bottle框架中实现最基本的get和post的方法的教程
2015/04/30 Python
python if not in 多条件判断代码
2016/09/21 Python
python urllib爬取百度云连接的实例代码
2017/06/19 Python
让Django支持Sql Server作后端数据库的方法
2018/05/29 Python
在Python IDLE 下调用anaconda中的库教程
2020/03/09 Python
PyCharm永久激活方式(推荐)
2020/09/22 Python
swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上
2013/07/06 面试题
记账会计岗位职责
2014/06/16 职场文书
上党课的心得体会
2014/09/02 职场文书
2014年房地产工作总结范文
2014/11/19 职场文书
青年干部培训班学习心得体会
2016/01/06 职场文书
初中思品教学反思
2016/02/20 职场文书