ajax--怎么用ajax做到无刷新


点击按钮触发下面js

<!-- ajax
核心-xmlhtprequest,一个专门http请求工具
xhr对象 request 服务器经过一些列response  浏览器没动xhr代替

如何创建xhr对象
new XMLHttpRequest()即可
考虑低版本ie678  new window.ActiveXObject('Microsoft.XMLHTTP')
 -->

 <img src="http://img3.imgtn.bdimg.com/it/u=4093643737,3232071282&fm=206&gp=0.jpg">
<input type="button" value="投票ajax" onclick="vote()" />

<div id="zt"></div>


再看js里

open里 get是不需要发送内容给服务器

post需要发送信息给服务器接收

<script type="text/javascript">
	function createXHR(){
		var xhr = null;
		if(window.XMLHttpRequest){
			xhr=new XMLHttpRequest();
		}else if(window.ActiveXObject){
			xhr=new	ActiveXObject('Microsoft.XMLHTTP');
		}
		return xhr;
	}

	function vote(){
		// 创造xhr
		var xhr=createXHR();
		// 打开连接
		xhr.open('GET','./2xhr.php',true);
		// 发送请求,到这一步就可以无刷新后台请求了
		xhr.send(null);

		/*但是,不知道是不是成功与否 所以服务器怎么获得返回信息呢 使投票可能失败
		xhr本身有一个属性,responseText 服务器返回信息的body主体内容,就是open里写的php得出的结果*/


		// alert(xhr.responseText);


		// 如果弹出的是空白的话,那就是开了异步
		/*true异步   不等到收到返回值就往下执行
		false同步   send完成并得到返回值*/

		/*使用异步,下面的继续执行,等请求完成怎么知道这个变化呢
		在异步的时候xhr请求响应的过程中,状态会不断变化,0-4逐步变化
		我们可以绑定一个函数,监听状态的变化,只要状态变化就触发某函数*/


		
		xhr.onreadystatechange = function(){
			var pg = document.getElementById('zt');
			pg.innerHTML=pg.innerHTML + '状态现在变成' + this.readyState + '<br/>';
		}
}		
/*
状态最终变成4就是ok
*/

</script>

主要这几点

1创造xhr

2 open打开连接 send 发送请求

3监听的函数

xhr.onreadystatechange = function(){}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值