您的位置:首页 > 理论基础 > 计算机网络

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

2016-01-22 16:21 423 查看
点击按钮触发下面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(){}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  php ajax http协议