ajax主要用于异步操作,与服务器或者其他网站进行交互,在不用刷新整个页面的情况下也可以更新数据
// 当然,这与服务器请求没有做跨域处理,所以会报错
<script>
var xhr=new XMLHttpRequest(); // 创建XMLHttpRequest,以进行ajax交互
// 侦听ajax对象的状态码是否改变,并声明ajax回调函数
xhr.onreadystatechange=function(){
if(xhr.readyState == 4 && xhr.status === 200){
console.log(xhr.responseText)
}else{
// 请求中
}
}
// 定义ajax的请求方法以及请求路由,是否启用异步,在服务器需要验证登录时后面还可以加两个参数,分别为用户名以及密码
xhr.open('GET','http://localhost:3002',true)
// 发送用户请求
xhr.send()
</script>
以上代码中的onreadystatechange变量为ajax的回调函数,通过侦听ajax返回的状态码变化,来判断请求是否完成
readyState的状态有五种
状态为 0 时,为 XMLHttpRequest 对象已经初始化状态,但是还没有调用open函数设置请求的方法以及路由等,
状态为 1 时,表示XMLHttpRequest对象正在向服务器发送数据,为正在进行时,XMLHttpRequest对象已经调用了open函数,并设置好了请求方法等
状态为 2 时,表示XMLHttpRequest对象已经接收完服务器的数据,但是还不能做进一步处理。也就是send方法执行完成,并且接受了服务器的数据,但是还没有处理数据
状态为 3 时,表示XMLHttpRequest对象正在解析服务器传过来的数据,根据服务器传过来的MIME类型进行解析成可以通过responseBody、responseText或responseXML属性存取的格式,但是处于解析中,为正在进行时
状态为 4 时,表示XMLHttpRequest对象已经解析完数据,可以在客户端进行操作了
XMLHttpRequest对象的整个流程就是,创建XMLHttpRequest对象,调用open方法设置请求的方法,请求的URL,是否启用异步(默认为true),还有两个可选参数(当服务器需要验证时启用)为用户名、密码,然后调用send方法发送数据给服务器端,设置回调函数来侦听状态码的变化,以判断进度。readState的状态变化为 :
创建XMLHttpRequest对象——>readState为 0(初始化请求)——>readState为 1 (发送请求)——>readState为 2(接收数据)——>readState为 3(解析数据)——>readState为 4(请求完成)
status状态码
常见的status概述(仅供参考)
0-199表示需要用户进一步操作,数据为临时响应数据
200-299表示成功处理了请求的代码
300-399为重定向状态码,表示如果要完成,需要进一步操作
400-499为请求错误,妨碍了服务器处理
500+为服务器错误,多为服务器内部错误,而不是请求端的错误