当前位置: 首页 > 图文教程 > 网络编程 > AJAX技术 > AJAX 随记

AJAX技术
用AJAX技术聚合RSS
Ajax 网址备忘
用javascript实现页面无刷新更新数据
ajax应用
AJAX入门之XMLHttpRequest慨述
AJAX入门之深入理解JavaScript中的函数
XMLHttpRequest of ajax
ajax 检测用户名是否被占用
开始研究Ajax. 第一天
ajax 不错的应用
Ajax技术(WEB无刷新提交数据)-
AJAX应用之注册用户即时检测
AJAX初体验之上手篇
ASP小偷程序如何利用XMLHTTP实现表单的提交
AJAX打造博客无刷新搜索
Flash & Ajax 操作 XML 实例:无刷新分页
Ajax 汇总以及初步评价
基于 Ajax 的无限级菜单
AJAX请求类
发布三个ajax相关的函数,包括无刷新提交表单等

AJAX技术 中的 AJAX 随记


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-13   浏览: 32 ::
收藏到网摘: n/a

使用AJAX可以提供无页面刷新便可以从后台更新页面数据,因此可以做出类似桌面应用的效果,但是每用一次AJAX便会用到大量的Javascript语句,今天我把整理了一下,使它变得结构化一些。 首先是一个创建AJAX的函数:
复制代码 代码如下:

var http_request=null;
function create_ajax(){
http_request = false;
//开始初始化XMLHttpRequest对象
if(window.XMLHttpRequest) { //Mozilla 浏览器
http_request = new XMLHttpRequest();
if (http_request.overrideMimeType) {//设置MiME类别
http_request.overrideMimeType('text/xml');
}
}
else if (window.ActiveXObject) { // IE浏览器
try {
http_request = new ActiveXObject("Msxml2.XMLHTTP");
} catch (e) {
try {
http_request = new ActiveXObject("Microsoft.XMLHTTP");
} catch (e) {}
}
}
if (!http_request) { // 异常,创建对象实例失败
window.alert("不能创建XMLHttpRequest对象实例.");
return false;
}
}

然后是调用这个函数来处理AJAX
复制代码 代码如下:

var obj1;
function get_ajax(url,obj) {//初始化、指定处理函数、发送请求的函数
obj1=obj;
create_ajax();
http_request.onreadystatechange =processobj; // 确定发送请求的方式和URL以及是否同步执行下段代码
http_request.open("POST", url, true);
http_request.send(null);
}
function processobj(){
document.getElementById(obj1).innerHTML="Loading...";
if (http_request.readyState == 4) { // 判断对象状态
if (http_request.status == 200) { // 信息已经成功返回,开始处理信息
document.getElementById(obj1).innerHTML=http_request.responseText;
} else { //页面不正常
document.getElementById(obj1).innerHTML="loading error.";
}
}
}

以上就是AJAX的主体,再在你需要用AJAX的页面把这段Javascript包含进去,就可以方便的调用了:
复制代码 代码如下:

<script type="text/javascript" src="ajax.js" src="ajax.js" ></script>
Welcome.
<div id="d1" onclick="get_ajax('ajax/get1.jsp','d1');">d1</div>
<div id="d2" onclick="get_ajax('ajax/get2.jsp','d2');">d2</div>
<div id="a">d2</div>

'ajax/get1.jsp'和'ajax/get2.jsp',是两个后台获取数据的页面,这样,一点击d1,get1.jsp就会被动态的加载进来,非常方便,当然这只是一个最基本的功能的模型,还可以在上面加上很多功能,大家自由发挥吧。