ajax onload怎么用,Ajax中onload和onreadystatechange两种请求方式的区别

一. onreadystatechange

1. XMLHttpRequest对象有一个属性readyState,将其(xhr.readyState)打印后发现。进入onreadystatechange请求方式中时,可以打印其状态为2,状态为3,状态为4。

请求纯文本

let btn = document.getElementById('btn');

btn.addEventListener("click",loadText);

function loadText(){

let xhr = new XMLHttpRequest();

xhr.open('GET','sample.txt',true);

xhr.onreadystatechange = function(){

console.log("READYSTATE"+ xhr.readyState);

console.log(this.responseText);

}

xhr.send();

}

2. readyState状态码和HTTP状态码

c4a88026a8d5778deee278312815f3bd.png

如果在上方代码中的open方法下,打印readyState属性,可得到状态码1

3. 可以利用网络请求码和readyState状态码进行判断

当网络请求码为200(服务器成功返回网页),readyState状态码为4时(请求已完成,响应已就绪),方可打印请求的数据。如图,在readyState状态码3的情况下不会再打印请求返回的数据。

function loadText(){

let xhr = new XMLHttpRequest();

xhr.open('GET','sample.txt',true);

console.log("READYSTATE"+ xhr.readyState);

xhr.onreadystatechange = function(){

console.log("READYSTATE"+ xhr.readyState);

if(this.status == 200 && this.readyState == 4){

console.log(this.responseText);

}else if(this.status == 404){

console.log("网页不存在");

}

}

xhr.send();

}

cfda1f30a8584f95ad1390f551eb6551.png

4. 如果此时将open中的路径改为一个错误路径,会产生如下效果

c76772a9b78361f8b1dfe52c8ffadd3c.png

二. onload

1. 进入onload之后,只出现了状态码4。也就是说,只有处于状态码4,请求已完成,响应已就绪的情况下,才会进入onload。只要进入onload请求中,一定是已经到4这个状态了。

function loadText(){

let xhr = new XMLHttpRequest();

xhr.open('GET','sample.txt',true);

console.log("READYSTATE"+ xhr.readyState);

//两种请求方式onload和onreadystatechange

xhr.onload = function(){

console.log("READYSTATE"+ xhr.readyState);

console.log(this.responseText);

}

xhr.send();

}

ba8bae52c39a4377cc8f01ba5d480c27.png

2. 此时如果修改open中的路径为错误路径的话,会出现如下状况。仍然会打印1和4,证明已经进入onload请求状态。这里报错的原因是,HTTP状态码不是200。

8143c7de911f3d5f43830bb11a0a90d4.png

vv

3. 实现页面尚未加载完成使,加载页面的实现(eg:进度条或转圈)。可用onprogress方法,打印readyState出现状态3

function loadText(){

let xhr = new XMLHttpRequest();

xhr.open('GET','sample.txt',true);

console.log("READYSTATE"+ xhr.readyState);

//两种请求方式onload和onreadystatechange

xhr.onprogress = function(){

console.log("测试加载状态READYSTATE"+ xhr.readyState);

}

xhr.onload = function(){

console.log("READYSTATE"+ xhr.readyState);

console.log(this.responseText);

}

xhr.send();

}

三. 将请求到的纯文本附在dom中

xhr.onload = function(){

document.getElementById('text').innerHTML = this.responseText;

}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值