关键字: 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()
{
     var dom=document.getElementById("name")    
    if(xmlHttp.readystate==)
     {

dom.value="正在连接服务器"
     }
    elseif(xmlHttp.readystate==|| xmlHttp.readystate==)
     {

dom.value="正在读取数据";
     }
    elseif(xmlHttp.readystate==)
     {
        if (xmlHttp.status==)
          {

dom.value=xmlHttp.responseText
         }
     }

}

</script>

2.XML基础教程:解析 XML DOM

读取、更新、创建或者操作某个XML文档,则需要XML解析器。

实例

解析XML文件 - 跨浏览器的实例
本例是一个跨浏览器的实例,把某个XML文档("note.xml")载入XML解析器。
解析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");
xmlDoc.async="false";
xmlDoc.load("note.xml");

上面的脚本的第一行创建了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);
xmlDoc.load("note.xml");

上面的脚本的第一行创建了XML解析器的一个实例。第二行会告知解析器载入名为"note.xml"的XML的文档。

解析某个XML文件 - 跨浏览器的实例

下面的例子是一个跨浏览器的实例,向XML解析器载入了某个已有的XML文档("note.xml"):

< html>
< head>
< script type="text/javascript">
var xmlDoc;
function loadXML()
{ // 用于 IE 的代码:
if (window.ActiveXObject)
{
xmlDoc=new ActiveXObject("Microsoft.XMLDOM");
xmlDoc.async=false;
xmlDoc.load("note.xml");
getmessage();
} // 用于 Mozilla, Firefox, Opera, 等浏览器的代码:
else if (document.implementation &&
document.implementation.createDocument)
{
xmlDoc=document.implementation.createDocument("","",null);
xmlDoc.load("note.xml");
xmlDoc.onload=getmessage;
}
else
{
alert('Your browser cannot handle this script');
}
} function getmessage()
{
document.getElementById("to").innerHTML=
xmlDoc.getElementsByTagName("to")[0].childNodes[0].nodeValue;
document.getElementById("from").innerHTML=
xmlDoc.getElementsByTagName("from")[0].childNodes[0].nodeValue;
document.getElementById("message").innerHTML=
xmlDoc.getElementsByTagName("body")[0].childNodes[0].nodeValue;
}
< /script>
< /head> < body onload="loadXML()">
< h1>W3Schools Internal Note< /h1>
< p>< b>To:< /b> < span id="to">< /span>< br />
< b>From:< /b> < span id="from">< /span>< br />
< b>Message:< /b> < span id="message">< /span>
< /p>
< /body>
< /html>

输出:

W3Schools Internal Note
To: Tove
From: Jani
Message: Don't forget me this weekend!

重要的注释

如需从某个XML元素(比如< from>Jani< /from>)中提取文本(比如Jani),请使用下面的语法:

getElementsByTagName("from")[0].childNodes[0].nodeValue

重要事项:getElementsByTagName会返回一个节点数组。此数组含有XML文档中拥有指定名称的所有元素。在这例子中,只有一个"from"元素,但是仍然需要设定数组的下标( [0] )。

解析一个XML字符串 - 跨浏览器的实例

下面的代码是一个跨浏览器的实例,向我们展示了如何加载和解析某个XML字符串:

< html>
< body> < script type="text/javascript"> var text="< note>";
text=text+"< to>Tove< /to>";
text=text+"< from>Jani< /from>";
text=text+"< heading>Reminder< /heading>";
text=text+"< body>Don't forget me this weekend!< /body>";
text=text+"< /note>"; // 用于 IE 的代码:
if (window.ActiveXObject)
{
var doc=new ActiveXObject("Microsoft.XMLDOM");
doc.async="false";
doc.loadXML(text);
} // 用于 Mozilla, Firefox, Opera, 等浏览器的代码:
else
{
var parser=new DOMParser();
var doc=parser.parseFromString(text,"text/xml");
} // documentElement 提交根元素:
var x=doc.documentElement; document.write("Text of first child element: ");
document.write(x.childNodes[0].childNodes[0].nodeValue);
document.write("< br />");
document.write("Text of second child element: ");
document.write(x.childNodes[1].childNodes[0].nodeValue);
< /script> < /body>
< /html>

输出:

Text of first child element: Tove
Text of second child element: Jani

注释:Internet Explorer使用loadXML()方法解析XML字符串,而Mozilla浏览器使用DOMParser对象。

根据以上两个说明,整理了如下的ajax工具

Ajax.js

  1. var net = new Object();
  2. net.READY_STATE_UNINITIALIZED=0;
  3. net.READY_STATE_LOADING=1;
  4. net.READY_STATE_LOADED=2;
  5. net.READY_STATE_INTERACTIVE=3;
  6. net.READY_STATE_COMPLETE=4;
  7. net.ContentLoader=function(url,onload,onerror){
  8. //this.url = encodeURI(url);
  9. this.url = url;
  10. this.req = null;
  11. this.onload = (onload) ? onload : this.defaultLoad;
  12. this.onerror = (onerror) ? onerror : this.defaulterror;
  13. this.loadXMLDoc(url);
  14. this.getText = this.defaultGetText;
  15. this.getXml = this.defaultGetXml;
  16. }
  17. net.ContentLoader.prototype={
  18. loadXMLDoc:function(url){
  19. if( window.XMLHttpRequest ){
  20. //Mozilla, Firefox, Opera
  21. this.req = new XMLHttpRequest();
  22. }else if( window.ActiveXObject ){
  23. try{
  24. //IE6.0
  25. this.req = new ActiveXObject("Microsoft.XMLHTTP");
  26. }catch(e1){
  27. try{
  28. xmlHttp=new ActiveXObject("MSXML2.XMLHTTP");
  29. }catch(e2){
  30. try{
  31. xmlHttp=new ActiveXObject("MSXML3.XMLHTTP");
  32. }catch(e3){
  33. }
  34. }
  35. }
  36. }
  37. if( this.req ){
  38. try{
  39. var loader = this;
  40. this.req.onreadystatechange = function(){
  41. loader.onReadyState.call(loader);
  42. }
  43. this.req.open('post',url,true);
  44. this.req.setRequestHeader("Content-Type", "text/html;charset=UTF-8");
  45. this.req.send(null);
  46. }catch(err){
  47. this.onerror.call(this);
  48. }
  49. }
  50. },
  51. onReadyState:function(){
  52. var req = this.req;
  53. var ready = req.readyState;
  54. if( ready == net.READY_STATE_COMPLETE ){
  55. var httpStatus = req.status;
  56. if( httpStatus == 200 || httpStatus == 0 ){
  57. this.onload.call(this);
  58. }else{
  59. this.onerror.call(this);
  60. }
  61. }
  62. },
  63. defaultError:function(){
  64. alert("error fetching date!"
  65. +"\n\nreadyState: "+this.req.readyState
  66. +"\nstatus: "+this.req.status
  67. +"\nheaders: "+this.req.getAllResponseHeaders()
  68. );
  69. },
  70. defaultLoad:function(){
  71. //do nothing
  72. },
  73. defaultGetXml:function(){
  74. var retXml = this.req.responseText;
  75. var xmlDoc = null;
  76. if( window.ActiveXObject ){
  77. //IE
  78. xmlDoc=new ActiveXObject("Microsoft.XMLDOM");
  79. xmlDoc.async=false;
  80. xmlDoc.load(retXml);
  81. }else{
  82. //Mozilla, Firefox, Opera
  83. var parser=new DOMParser();
  84. xmlDoc = parser.parseFromString(retXml,"text/xml");
  85. }
  86. return xmlDoc;
  87. },
  88. defaultGetText:function(){
  89. return this.req.responseText;
  90. }
  91. }
标签: javascript, ajax

简易的AJAX工具[转]的更多相关文章

  1. JavaScript之简易http接口测试工具网页版

    简易http接口测试工具网页版,支持get.post请求,支持json格式消息体,form表单暂不支持. httpClient.html <!DOCTYPE html> <html ...

  2. jquery+flask+keras+nsfw快速搭建一个简易鉴黄工具

    1. demo 地址:http://www.huchengchun.com:8127/porn_classification 接口说明: 1. http://www.huchengchun.com:8 ...

  3. AJAX编程-封装ajax工具函数

    即 Asynchronous [e'sɪŋkrənəs] Javascript And XML,AJAX 不是一门的新的语言,而是对现有技术的综合利用.本质是在HTTP协议的基础上以异步的方式与服务器 ...

  4. HTML5简易在线画图工具

    继上次学习了HTML5的路径画圆做了动态时钟.异次元空间的反转做了运动的太阳系,这两天将画线.画圆.填充等知识点结合起来做了一个简易的在线画图工具: 查看DEMO:HTML5简易在线画图工具 功能包括 ...

  5. 封装一个Ajax工具函数

    /*封装一个ajax工具函数*/ window.$ = {}; /*通过$定义一个ajax函数*/ /* * 1. type   string   请求的方式  默认是get * 2. url     ...

  6. JavaScript封装Ajax工具函数及jQuery中的ajax,xhr在IE的兼容

    封装ajax工具函数 首先要思考:1.为什么要封装它?提高开发效率2.把一些不确定的情况考虑在其中 a. 请求方式 b. 请求地址 c. 是否异步 d. 发送参数 e. 成功处理 f. 失败处理3.确 ...

  7. 基于WebServices简易网络聊天工具的设计与实现

    基于WebServices简易网络聊天工具的设计与实现 Copyright 朱向洋 Sunsea ALL Right Reserved 一.项目内容 本次课程实现一个类似QQ的网络聊天软件的功能:服务 ...

  8. 基于JavaScript封装的Ajax工具类

    前段是件由于工作需要无奈编写了一个给予JavaScript封装的工具类,技术有限,误喷,感谢大家的支持. 1.以下是JavaScript 的 Ajax 工具类. function createXMLH ...

  9. 基于Java的简易表达式解析工具(一)

    最近需要用到相关表达式解析的工具,然后去网上搜索,找到了一个用C#写的表达式解析工具,仔细看了功能后发现,这正是我需要的,如果我能将它改造成基于Java语言的方式,岂不是更好吗,所以花了一段时间,把网 ...

随机推荐

  1. ecshop后台增加模块菜单项详细教程(图文)

    有的时候我们会在后台增加新的功能,菜单项是一个程序的入口,是必不可少的,如何在后台增加菜单项呢,大家可以参考下面的教程:   例如:想在后台左侧的菜单栏的"促销管理"下添加一个&q ...

  2. hdu_4467_Graph(莫队算法思想)

    题目连接:hdu_4467_Graph 题意:给你n个点,m条边,每条边有一个权值,有两个操作,一个是修改单点的颜色,一个是询问边的两个端点都为指定颜色的权值和 题解:这题如果暴力的话,就是维护3个a ...

  3. 【项目笔记】【bug】数组空指针异常

    package com.example.googleplay.ui.holder; import java.util.ArrayList; import android.view.View; impo ...

  4. Linux的环境变量

     一.Linux的变量种类 按变量的生存周期来划分,Linux变量可分为两类: 1.永久的:需要修改配置文件,变量永久生效. 2.临时的:使用export命令声明即可,变量在关闭shell时失效. 二 ...

  5. vim Podfile

    platform :ios, "7.0"pod "AFNetworking"pod "SDWebImage"pod "SVProg ...

  6. HDU 1711 Number Sequence(KMP匹配数字串)

    这个就是kmp的数组形式,不用来处理字符串还真有点不习惯呢... #include<iostream> using namespace std; ,MAXM = ; int T[MAXN] ...

  7. sql查询技巧,按时间分段进行分组,每半小时一组统计组内记录数量

    今天拿到一个查询需求,需要统计某一天各个时间段内的记录数量. 具体是统计某天9:00至22:00时间段,每半小时内订单的数量,最后形成的数据形式如下: 时间段          订单数 9:00~9: ...

  8. Dojo和jQuery区别

    Dojo类似jQuery,且用法也差不多,但是Dojo属于重量级的框架,自带的表单验证,Grid,tree等控件. 在选择上,个人觉得轻量级的框架比较好,因为方便引入第三方的,有特色的库. 就像选择S ...

  9. Fastjson简单使用方法

    一.简单数据的序列化 pubic class UserInfo implements Serializable{ private String name; private int age; publi ...

  10. android里uri和url的区别

    URI :是从虚拟根路径开始的 URI,是uniform resource identifier URL:是整个链接  URI,是uniform resource location uri:file: ...