通过 xhr.timeout 来设置超时时间,然后调用超时回调函数
const xhr = new XMLHttpRequest();
//设置请求超时时间 如果在设置时间内 服务端还没有返回数据 则提示请求超时
xhr.timeout = 2000; // 2秒超时 会中断(取消)本次请求
//超时回调
xhr.ontimeout = function(){
alert("请求超时,请稍后重试...");
}
//网络异常回调(比如掉线)
xhr.onerror = function(){
alert("糟糕,你的网络出了问题...");
}
xhr.open('get','http://127.0.0.1:8000/delay');
xhr.send();
xhr.onreadystatechange = function(){
if(xhr.readyState === 4){
if(xhr.status >= 200 && xhr.status < 300){
//在这里进行请求成功后的处理
//result.innerHTML = xhr.response;
}
}
}
服务脚本:
//1 引入express
const express = require('express');
//2 创建应用对象
const app = express();
app.get('/delay',(request,response)=>{
//设置响应头 设置允许跨域
response.setHeader('Access-Control-Allow-Origin','*');
//设置响应体 3s后响应
setTimeout(function(){
response.send('hello delay');
},3000);
});
//4 监听端口
app.listen(8000,()=>{
console.log('服务器已启动...');
})
小案例完整代码:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
#result{
width: 200px;
height: 100px;
border: 1px solid #90b;
}
</style>
</head>
<body>
<button id="btn">点击发送请求</button>
<div id="result"></div>
<script>
const result = document.getElementById("result");
const btn = document.getElementById("btn")
btn.addEventListener('click',function(){
const xhr = new XMLHttpRequest();
//设置请求超时时间 如果在设置时间内 服务端还没有返回数据 则提示请求超时
xhr.timeout = 2000; // 2秒超时 会中断(取消)本次请求
//超时回调
xhr.ontimeout = function(){
alert("请求超时,请稍后重试...");
}
//网络异常回调(比如掉线)
xhr.onerror = function(){
alert("糟糕,你的网络出了问题...");
}
xhr.open('get','http://127.0.0.1:8000/delay');
xhr.send();
xhr.onreadystatechange = function(){
if(xhr.readyState === 4){
if(xhr.status >= 200 && xhr.status < 300){
result.innerHTML = xhr.response;
}
}
}
})
</script>
</body>
</html>