三重水的博客

在变化当中不断记录自己,充实自己,浏览自己

原生AJAX

为了方便,我们一直用jquery写AJAX异步获取数据,要是别人问,您能否用原生的javascript自己写一个异步获取数据的脚本呢?我想应该很多人都忘记了。

AJAX是什么?

AJAX = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)。

AJAX 不是新的编程语言,而是一种使用现有标准的新方法。

AJAX 是与服务器交换数据并更新部分网页的艺术,在不重新加载整个页面的情况下。

XMLHttpRequest对象

其实,这个技术无非就是一个XMLHttpRequest对象而已,只要你熟悉这个对象的API的使用即可实现异步加载你想要的数据。

那怎么来创建这个对象呢?

创建对象XMLHttpRequest

1
var xmlHttp = new XMLHttpRequest();

要是不用兼容旧浏览器IE5和IE6 就是以上一行代码即可创建这个对象。当然现在IE5和IE6,可以说淘汰了,所以就不兼容它了,没必要。想要兼容它就加个if判断即可,它的创建方式如下:

1
2
3
4
5
6
7
8
var xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
//判断如:
var xmlHttp;
if(window.XMLHttpRequest){//现代浏览器
    xmlHttp = new XMLHttpRequest();
}else{//旧版浏览器IE5、IE6
    xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}

以下给出的实例都不考虑旧版浏览器了,淘汰了没必要。

这个对象有如下3个方法和5个属性,如下

方法:

1、 xmlHttp.open(method,url,async);

参数method:规定请求的类型;GET或POST

参数url: 请求的地址;

参数async: true(异步)或false(同步)。

GET 还是 POST?

与 POST 相比,GET 更简单也更快,并且在大部分情况下都能用。

然而,在以下情况中,请使用 POST 请求:

  • 无法使用缓存文件(更新服务器上的文件或数据库)
  • 向服务器发送大量数据(POST 没有数据量限制)
  • 发送包含未知字符的用户输入时,POST 比 GET 更稳定也更可靠

2、 xmlHttp.send(string)

将请求发送到服务器

参数String:仅用于POST请求

3、 xmlHttp.setRequestHeader(header, value)

向请求添加http头

header:规定头的名称

value:规定头的值

如:xmlhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); 这个是告诉服务器端以这个类型类解析数据

属性:

1、 onreadystatechange : 存储函数(或函数名),每当 readyState 属性改变时,就会调用该函数。

2、 readyState:

存有 XMLHttpRequest 的状态。从 0 到 4 发生变化。

  • 0 请求未初始化
  • 1 服务器连接已建立
  • 2 请求已接收
  • 3 请求处理中
  • 4 请求已完成,且响应已就绪

3、 status:

200:“ok”

404:“未找到页面”

一般接收服务器返回的数据写法如下:

1
2
3
4
5
6
7
xmlhttp.onreadystatechange= function()
  {
  if (xmlhttp.readyState === 4 && xmlhttp.status === 200)
    {
    document.getElementById("myDiv").innerHTML=xmlhttp.responseText;//获得字符串形式的响应数据。
    }
  } 

4、 responseText: 获得字符串形式的响应数据。

5、 responseXML : 获得 XML 形式的响应数据。

代码实战

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>ajax</title>
</head>
<body>
<button id="getAjax1">获取responseText</button>
<button id="getAjax2">获取responseXML</button>
<br/>
<div>
    <p>responseText返回的文本:<span id="output1"></span></p>
    <p>responseXML返回的文本:<span id="output2"></span></p>
</div>
<script>
    //采用模块模式来封装代码
    var myAjax = (function(){
        function Temp(){
            this.xmlHttp = new XMLHttpRequest();
        }
        Temp.prototype.init =function(method, url, callback) {
            var self = this;
            this.xmlHttp.onreadystatechange=function(){
                if(self.xmlHttp.readyState === 4 && self.xmlHttp.status === 200){
                    callback(self.xmlHttp);
                }
            };
            this.xmlHttp.open(method,url,true);
            this.xmlHttp.send();
        };
       return{
           ajax: function(method, url, callback) {
               var ajaxChild = new Temp();
               ajaxChild.init(method, url, callback);
           }
       }
    })();
    //测试用例
    document.getElementById('getAjax1').onclick = function() {
        myAjax.ajax('GET', 'demo.php?name=wen', function (xmlHttp) {//获取responseText文本数据
            document.getElementById('output1').innerHTML = xmlHttp.responseText;
            console.log(xmlHttp.responseText);
        })
    };
    document.getElementById('getAjax2').onclick = function() {
        myAjax.ajax('GET', 'demo.xml',function(xmlHttp){//获取responseXML文档对象
            var xmlEleValue = xmlHttp.responseXML.getElementsByTagName('name')[0].firstChild.nodeValue;
            document.getElementById('output2').innerHTML=xmlEleValue;
            console.dir(xmlHttp.responseXML);
        });
    }
</script>
</body>
</html>

demo.php

1
2
<?php
echo "hello world";

demo.xml

1
2
<?xml version="1.0" encoding="UTF-8"?>
<name>wen</name>

以上用到的源码可以到我的github下载ajax-text

参考链接

菜鸟教程-AJAX教程

评论