ajax原理的简单实现

Ajax的主要作用就是不刷新页面更新页面的内容,也就是异步传输。用来显示Ajax响应的div。下面就是一段使用Ajax的简单示例。

function ajaxRequest(){
	var req = false;
	if(window.XMLHttpRequest) {
		var req = new window.XMLHttpRequest();
	} else if (window.ActiveXObject) {
		var req = new window.ActiveXObject('Microsoft.XMLHTTP');
	}
	if(!req) return false;
	req.onreadystatechange = callback;
	req.open('GET','ajax/ajaxTest.txt',true);
	req.setRequestHeader('Accept-Language','zh-cn');
	req.send(null);
	function callback(){
		switch (req.readyState) {
			case 1:
				//alert('Loading');
				break;
			case 2:
				//alert('loaded');
				break;
			case 3:
				//alert('Interactive');
				break;
			case 4:
				if (req.status && req.status == 200){
					var str = req.responseText;
					document.getElementById('test').innerHTML = str;
				}
				break;
		}	
	}
}
function addEventSimple(obj,evt,fn){
	if(obj.addEventListener){
		obj.addEventListener(evt,fn,false);
	}else if(obj.attachEvent){
		obj.attachEvent('on'+evt,fn);
	}
}
addEventSimple(document,'dblclick',ajaxRequest);

代码的最后部分给document添加一个双击的响应函数,当文档被双击的时候就调用ajaxRequest函数,也就是负责发送Ajax请求的函数。

ajaxRequest函数中,第一步就是创建一个XMLHttpRequest对象,代码如下,由于IE和其它浏览器支持的方式不太一样,所以会试图使用使用两个方法来创建这个对象。

	var req = false;
	if(window.XMLHttpRequest) {
		var req = new window.XMLHttpRequest();
	} else if (window.ActiveXObject) {
		var req = new window.ActiveXObject('Microsoft.XMLHTTP');
	}
	if(!req) return false;

第二步是设置XMLHttpRequest对象的状态变化响应函数。

	req.onreadystatechange = callback;

  

下面是发送Ajax请求了。

	req.open('GET','ajax/ajaxTest.txt',true);
	req.send(null);

最后就可以编写状态变化响应函数了:

function callback(){
 switch (req.readyState) {
  case 1:
  //alert('Loading');
  break;
  case 2:
  //alert('loaded');
  break;
  case 3:
  //alert('Interactive');
  break;
  case 4:
   if (req.status && req.status == 200){
    var str = req.responseText;
    document.getElementById('test').innerHTML = str;
   }
   break;
 }	
}

函数的作用就是将返回的字符串添加到页面开头id为test的div内。双击这个文档就可以看到效果。

<!-- #BeginLibraryItem "/Library/Ajax笔记.lbi" -->
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值