简易的AJAX工具[转]
1.创建XMLHttpRequest对象的js文件
| Ajax.js
function Ajax()
{ var xmlHttp=null; if(window.XMLHttpRequest) {//非IE内核浏览器 xmlHttp=new XMLHttpRequest(); } elseif(window.ActiveXObject) {//IE内核浏览器 try {//IE6.0 xmlHttp=new ActiveXObject("Microsoft.XMLHTTP"); } catch(e1) { try { xmlHttp=new ActiveXObject("MSXML2.XMLHTTP"); } catch(e2) { try { xmlHttp=new ActiveXObject("MSXML3.XMLHTTP"); } catch(e3) { alert("创建Ajax失败:"+e3) } } } } else {//未知浏览器 alert("未能识别的浏览器"); } return xmlHttp; } 放到创建对象的页面 <script language="javascript" type="text/javascript" src="Ajax.js"></script>用asp举个例子 <script language="javascript" type="text/javascript" src="Ajax.js"></script>
<script language="javascript" type="text/javascript"> var xmlHttp=new Ajax(); function checkName() { xmlHttp.onreadystatechange=getName; xmlHttp.open("get","getName.asp",true); xmlHttp.send(null) } function getName() dom.value="正在连接服务器" dom.value="正在读取数据"; dom.value=xmlHttp.responseText } </script> |
|
2.XML基础教程:解析 XML DOM 读取、更新、创建或者操作某个XML文档,则需要XML解析器。 实例
解析一个XML文档如需操作某个XML文档,您需要XML解析器。解析器会将文档载入电脑的内存中。一旦文档被载入,可使用DOM对其数据进行操作。DOM把XML作为一颗树来处理。 微软的XML解析器与Mozilla浏览器中使用的解析器是有差异的。在本教程中,我们会为您展示如何创建可工作于IE和Mozilla浏览器中的跨浏览器脚本。 微软的XML解析器微软的XML解析器是存在于IE 5.0或更高版本中的COM组件。一旦你安装了IE,就可使用脚本来利用解析器了。 微软的XML解析器支持所有必要的功能,来遍历节点树,访问节点以及它们的属性值,插入并删除节点,并将节点数转换回XML。 如需创建微软XML解析器的一个实例,请使用下面的代码: JavaScript:var xmlDoc=new ActiveXObject("Microsoft.XMLDOM");
VBScript:set xmlDoc=CreateObject("Microsoft.XMLDOM")
ASP:set xmlDoc=Server.CreateObject("Microsoft.XMLDOM")
下面的代码段可向微软的XML解析器载入一个已有的XML文档("note.xml"): var xmlDoc=new ActiveXObject("Microsoft.XMLDOM");
上面的脚本的第一行创建了XML解析器的一个实例。第二行关闭了同步载入,这样可以确保在文档被完全载入前解析器不会继续执行。第三行会告知解析器载入名为"note.xml"的XML的文档。 Mozilla、Firefox以及Opera中的XML解析器Mozilla浏览器的XML解析器支持所有必要的功能,来遍历节点树,访问节点以及它们的属性值,插入并删除节点,并将节点树转换回XML。 如需创建Mozilla浏览器的XML解析器的一个实例,请使用下面的代码: JavaScript:var xmlDoc=document.implementation.createDocument("ns","root",null);
第一个参数,ns,定义用于XML文档的命名空间(namespace)。第二个参数,root,是XML文件中的XML根元素。第三个参数,null,一般总是null,这是由于目前还没有用到这个参数。 下面的代码段可向Mozilla浏览器的XML解析器载入一个已有的XML文档("note.xml"): var xmlDoc=document.implementation.createDocument("","",null);
上面的脚本的第一行创建了XML解析器的一个实例。第二行会告知解析器载入名为"note.xml"的XML的文档。 解析某个XML文件 - 跨浏览器的实例下面的例子是一个跨浏览器的实例,向XML解析器载入了某个已有的XML文档("note.xml"): < html> 输出:W3Schools Internal Note 重要的注释如需从某个XML元素(比如< from>Jani< /from>)中提取文本(比如Jani),请使用下面的语法: getElementsByTagName("from")[0].childNodes[0].nodeValue
重要事项:getElementsByTagName会返回一个节点数组。此数组含有XML文档中拥有指定名称的所有元素。在这例子中,只有一个"from"元素,但是仍然需要设定数组的下标( [0] )。 解析一个XML字符串 - 跨浏览器的实例下面的代码是一个跨浏览器的实例,向我们展示了如何加载和解析某个XML字符串: < html> 输出:Text of first child element: Tove 注释:Internet Explorer使用loadXML()方法解析XML字符串,而Mozilla浏览器使用DOMParser对象。 根据以上两个说明,整理了如下的ajax工具 |
Ajax.js
- var net = new Object();
- net.READY_STATE_UNINITIALIZED=0;
- net.READY_STATE_LOADING=1;
- net.READY_STATE_LOADED=2;
- net.READY_STATE_INTERACTIVE=3;
- net.READY_STATE_COMPLETE=4;
- net.ContentLoader=function(url,onload,onerror){
- //this.url = encodeURI(url);
- this.url = url;
- this.req = null;
- this.onload = (onload) ? onload : this.defaultLoad;
- this.onerror = (onerror) ? onerror : this.defaulterror;
- this.loadXMLDoc(url);
- this.getText = this.defaultGetText;
- this.getXml = this.defaultGetXml;
- }
- net.ContentLoader.prototype={
- loadXMLDoc:function(url){
- if( window.XMLHttpRequest ){
- //Mozilla, Firefox, Opera
- this.req = new XMLHttpRequest();
- }else if( window.ActiveXObject ){
- try{
- //IE6.0
- this.req = new ActiveXObject("Microsoft.XMLHTTP");
- }catch(e1){
- try{
- xmlHttp=new ActiveXObject("MSXML2.XMLHTTP");
- }catch(e2){
- try{
- xmlHttp=new ActiveXObject("MSXML3.XMLHTTP");
- }catch(e3){
- }
- }
- }
- }
- if( this.req ){
- try{
- var loader = this;
- this.req.onreadystatechange = function(){
- loader.onReadyState.call(loader);
- }
- this.req.open('post',url,true);
- this.req.setRequestHeader("Content-Type", "text/html;charset=UTF-8");
- this.req.send(null);
- }catch(err){
- this.onerror.call(this);
- }
- }
- },
- onReadyState:function(){
- var req = this.req;
- var ready = req.readyState;
- if( ready == net.READY_STATE_COMPLETE ){
- var httpStatus = req.status;
- if( httpStatus == 200 || httpStatus == 0 ){
- this.onload.call(this);
- }else{
- this.onerror.call(this);
- }
- }
- },
- defaultError:function(){
- alert("error fetching date!"
- +"\n\nreadyState: "+this.req.readyState
- +"\nstatus: "+this.req.status
- +"\nheaders: "+this.req.getAllResponseHeaders()
- );
- },
- defaultLoad:function(){
- //do nothing
- },
- defaultGetXml:function(){
- var retXml = this.req.responseText;
- var xmlDoc = null;
- if( window.ActiveXObject ){
- //IE
- xmlDoc=new ActiveXObject("Microsoft.XMLDOM");
- xmlDoc.async=false;
- xmlDoc.load(retXml);
- }else{
- //Mozilla, Firefox, Opera
- var parser=new DOMParser();
- xmlDoc = parser.parseFromString(retXml,"text/xml");
- }
- return xmlDoc;
- },
- defaultGetText:function(){
- return this.req.responseText;
- }
- }
简易的AJAX工具[转]的更多相关文章
- JavaScript之简易http接口测试工具网页版
简易http接口测试工具网页版,支持get.post请求,支持json格式消息体,form表单暂不支持. httpClient.html <!DOCTYPE html> <html ...
- jquery+flask+keras+nsfw快速搭建一个简易鉴黄工具
1. demo 地址:http://www.huchengchun.com:8127/porn_classification 接口说明: 1. http://www.huchengchun.com:8 ...
- AJAX编程-封装ajax工具函数
即 Asynchronous [e'sɪŋkrənəs] Javascript And XML,AJAX 不是一门的新的语言,而是对现有技术的综合利用.本质是在HTTP协议的基础上以异步的方式与服务器 ...
- HTML5简易在线画图工具
继上次学习了HTML5的路径画圆做了动态时钟.异次元空间的反转做了运动的太阳系,这两天将画线.画圆.填充等知识点结合起来做了一个简易的在线画图工具: 查看DEMO:HTML5简易在线画图工具 功能包括 ...
- 封装一个Ajax工具函数
/*封装一个ajax工具函数*/ window.$ = {}; /*通过$定义一个ajax函数*/ /* * 1. type string 请求的方式 默认是get * 2. url ...
- JavaScript封装Ajax工具函数及jQuery中的ajax,xhr在IE的兼容
封装ajax工具函数 首先要思考:1.为什么要封装它?提高开发效率2.把一些不确定的情况考虑在其中 a. 请求方式 b. 请求地址 c. 是否异步 d. 发送参数 e. 成功处理 f. 失败处理3.确 ...
- 基于WebServices简易网络聊天工具的设计与实现
基于WebServices简易网络聊天工具的设计与实现 Copyright 朱向洋 Sunsea ALL Right Reserved 一.项目内容 本次课程实现一个类似QQ的网络聊天软件的功能:服务 ...
- 基于JavaScript封装的Ajax工具类
前段是件由于工作需要无奈编写了一个给予JavaScript封装的工具类,技术有限,误喷,感谢大家的支持. 1.以下是JavaScript 的 Ajax 工具类. function createXMLH ...
- 基于Java的简易表达式解析工具(一)
最近需要用到相关表达式解析的工具,然后去网上搜索,找到了一个用C#写的表达式解析工具,仔细看了功能后发现,这正是我需要的,如果我能将它改造成基于Java语言的方式,岂不是更好吗,所以花了一段时间,把网 ...
随机推荐
- ssh能够连接而sftp不能连接的解决方法
ssh能够连接而sftp不能连接的解决方法 昨天开始用FileZilla一直不能登录远程的服务器,ssh的登录就OK,因为是服务器,也不敢乱动.查了好多资料终于解决了. 首先,查看一下系统的安全日 ...
- 支付宝集成+网站支付+APP支付+手机网站支付
网站支付宝 1.申请签约后获得相应的pid:208***开头和key 这里说明下pc网站支付采用md5加密所以这里只需要提供pid和key不需要上传公钥. 2.下载即时到账demo http://do ...
- C#实现拷贝对象
大家都知道,在C#中变量的存储分为值类型和引用类型两种,而值类型和引用类型在数值变化是产生的后果是不一样的,值类型我们可以轻松实现数值的拷贝,那么引用类型呢,在对象拷贝上存在着一定的难度. 下 ...
- Web应用的组件化(二)——管控平台 #7
Web应用的组件化(二) 管控平台 在上一篇中我们提到了组件化的大致思路,这一篇主要讲述在这么做之后,我们需要哪些外围手段去管控整个开发过程.从各种角度看,面对较大规模前端开发团队,都有必要建立这么一 ...
- Textbox服务器控件
<body> <form id="form1" runat="server"> <div> 姓名:<asp:TextB ...
- EXCEL读写NPOI
1.第一步: 可以使用ExcelAutomation进行EXCEl文件的读写,但是需要电脑上安装EXCEL,对EXCEL版本有要求,速度慢,有安全性,并发性问题,不适合网站类项目. 第二种方法: NP ...
- poj 3628 Bookshelf 2 基本01背包
题目大意:FJ有n头奶牛,和一个高为h的架子,给出每头奶牛高度,求使奶牛叠加起来超过架子的最低高度是多少. 题目思路:求出奶牛叠加能达到的所有高度,并用dp[]保存,最后进行遍历,找出与h差最小的dp ...
- 小红的难题<递推>
题意:五个数:N,x,y,A,B;N是台阶总数,x,y是每步可以走x或者y步,但是一定要走到A,B台阶上. 思路:学长给的题解,递推,稍微优化一点. >重点在递推 #include<cst ...
- zencart侧边导航点击一级目录展开二级目录
[小 大] 2013-09-17 00:20 来源: 未知 作者:wtozz_admin 我要投稿 zencart侧边导航点击一级目录展开二级目录 zen cart Categories默认的是只显示 ...
- 对于使用了SSH造成的中文乱码问题,4大解决方法
修改struts2.xml struts2.xml 中添加 <constant name="struts.i18n.encoding" value="UTF-8&q ...
<script language="javascript" type="text/javascript" src="Ajax.js"></script>