因为Ajax的定义如下:

在html,js,xml中使用Ajax_html

需要使用到服务器端,所以,创建一个web项目

在html,js,xml中使用Ajax_javascript_02

新建一个files文件夹:

在html,js,xml中使用Ajax_xml_03

在index.jsp中添加如下代码:

<body>
<button id="button">点击测试ajax</button><b id="b"></b>
</body>

在添加Ajax代码:

<script type="text/javascript">
window.onload = function() {
var butn = document.getElementById("button");
butn.onclick = function() {
var request = new XMLHttpRequest();
var method="GET";
var url="files/getreturn.html";
request.open(method, url);
request.send(null);
request.onreadystatechange = function() {
if(request.readyState == 4 && request.status == 200)
document.getElementById("b").innerHTML = request.responseText;
}
}
}
</script>

在files文件夹中建立一个HTML文件,在里面写入如下代码:

<meta http-equiv="content-type" content="text/html; charset=utf-8" />
这是GET返回的信息。

2.第一个例子到这里就写完了,使用Ajax调用HTML中的数据,但是现在还不能看到效果,需要把项目添加到服务器中

在html,js,xml中使用Ajax_服务器_04



在图中,并没有我们的项目,所以需要把项目加入到服务器中:

在html,js,xml中使用Ajax_xml_05

加入我们的项目后,启动服务器:

在html,js,xml中使用Ajax_xml_06

启动:

在html,js,xml中使用Ajax_xml_07

在浏览器查看效果:

在浏览器输入:http://localhost:8080/test

在html,js,xml中使用Ajax_服务器_08

点击按钮:

在html,js,xml中使用Ajax_ajax_09

发现url没有改变,也就是说页面没有刷新,但是在button后面却刷新了一部分,这就是Ajax的方法,实现局部刷新

3.Ajax调用js文件中的数据:

在files文件夹下创建一个js文件,写入如下代码:

{"person":{

"name":"bill",
"value":"how are you"
}
}

保存之后发现有错,解决方法:

在html,js,xml中使用Ajax_xml_10

选中js文件,右键->MyEclipse->Exclude From Validation,等下就OK了

在html,js,xml中使用Ajax_javascript_11

在js文件中写入如下代码:

{"person":{

"name":"bill",
"value":"how are you"
}
}

在index.jsp中写下如下代码:

<body>
<button id="button">点击测试ajax</button><b id="b"></b><br>
<button id="button" οnclick="clk()">点击测试ajax与js</button><b id = "b1"></b>
</body>

在index.jsp中添加代码:

function clk(){
var reqst = new XMLHttpRequest();
var method = "GET";
var url = "files/myjs.js";
reqst.open(method, url);
reqst.send(null);
reqst.onreadystatechange = function() {
if(reqst.readyState == 4 && reqst.status == 200)
{
var result = reqst.responseText;

var obj = eval("(" + result + ")");
document.getElementById("b1").innerHTML ="name:" + obj.person.name + " value:" +obj.person.value;
}
}
}

4.OK,在浏览器上刷新界面:

在html,js,xml中使用Ajax_ajax_12


点击第二个button:

在html,js,xml中使用Ajax_ajax_13


两个button都进行测试:

在html,js,xml中使用Ajax_服务器_14


5.现在该写Ajax在XML中获取数据:

在files文件夹下创建XML文件:

写入如下代码:

<?xml version="1.0" encoding="UTF-8"?>
<details>
<name>Jeremy Keith</name>
<value>你好啊</value>
</details>

在index.jsp中添加如下代码:

<button οnclick="ckk()">点击测试ajax与xml</button><b id = "b2"></b>

在index.jsp中添加如下代码:

function ckk(){
var request = new XMLHttpRequest();
var method = "GET";
var url = "files/MyXml.xml";
request.open(method, url);
request.send(null);
request.onreadystatechange = function() {
if(request.readyState == 4 && request.status == 200){
var result = request.responseXML;
var name = result.getElementsByTagName("name")[0].firstChild.nodeValue;
var v = result.getElementsByTagName("value")[0].firstChild.nodeValue;
document.getElementById("b2").innerHTML = "name:"+name+" value:"+v;
}
}
}

6.现在来进行测试:

在html,js,xml中使用Ajax_javascript_15



点击点三个button:

在html,js,xml中使用Ajax_javascript_16


点击三个button:

在html,js,xml中使用Ajax_xml_17

至此,这个小项目就完成了,

总结一下,这个项目主要实现了利用Ajax方法分别在HTML,js,XML数据源中获取数据,并对界面进行局部刷新。