今天来说说超时,我们先来简单介绍下:
说到超时,时延,我们知道有setTimeout和setInterval方法,这两个写法差不多;
两者大致的写法:
setTimeout(code,毫秒)
setInterval(code,毫秒)
只是setTimeout方法只执行一次,setInterval是隔一段时间执行一次。
setTimeout
可以写成:
//3秒执行alert弹框
setTimeout( "alert('对不起, 三秒钟已到')" , 3000 )
也可以时延直接调用某方法:
//有个方法
function fangfa(){
//方法区
alert(“hello”)
}
//3秒执行该方法
setTimeout( this.fangfa , 3000 )
不能写成,就是不能直接输出字符串:
//错误写法,会报错
setTimeout( "hello" , 3000 )
我们可以把方法进行合并:
setTimeout(
function(){
//方法区
alert("Hello");
}
, 3000);
但这种写法,如果再VUE里就不能时延this,我们可以改写成:
setTimeout(
e => {
//方法区
this.alert("Hello"); ;
}
,3000);
setInterval
这个写法同上面类似,setTimeout改成setInterval就行。略
基于webscoket时延处理
我们在发送请求的时候,有几种可能:1.对方没回;2.自己发送失败,对方没有收到;
这时候我们其实一直在等待,但是等多久?我们要给出超时提示。
这里大家会觉得使用setTimeout不就行了,没错,直接使用setTimeout,但是呢,实测中,如果你直接使用setTimeout,无论你超不超时,setTimeout它都会执行。
setTimeout(
e => {
this.loading = false//设置一个加载
this.$message({
showClose: true,
message: '发送超时,请重新操作',
type: 'error'
});
}
,30000);
但这个不是我们要的效果,我们需要的是超时才执行它,不超时就不执行。这个可能有的会有好几种办法,但是百度了下,没有看到相同的做法。
有个方法是,做个心跳监测,但是这个需要后端配合,可是后端不配合,这种抛弃。感兴趣的可以参考:
我的想法是,我们在发送的时候,设置setTimeout,如果对方回复了,那么我们就可以取消setTimeout这个定时器,这里用到clearTimeout方法。
clearTimeout
这个网上的写法是:
var chaoshi = setTimeout( "alert('对不起, 三秒钟已到')" , 3000 )//3秒执行alert弹框
//清除定时器
clearTimeout(this.chaoshi);
但是我在VUE中我很纳闷,chaoshi这个是什么类型?所以多次尝试下VUE的完整写法:
data() {
return {
chaoshi:null,//存放setTimeout的
}
}
methods:{
发送方法(){
//发送请求方法里
this.send(请求内容)//假设这是发送的请求
this.loging = true;//如果你设置加载中的页面用这个element加载组件
//重点
setTimeout(
e => {
this.loading = false//加载解锁
//超时后提示语
this.$message({
showClose: true,
message: '发送超时,请重新操作',
type: 'error'
});
}
,30000);
}
接收方法(){ //假设这里是你专门接收后端返回数据的地方
//接收内容
this.loading = false; //接收到内容肯定是解锁加载
//重点
clearTimeout(this.chaoshi);
this.chaoshi = null;//重置下这个
}
}
上面这个是局部的位置,如果你的整个项目基于webscoket发送请求(主方法,全局),或者其他也行,让所有请求都等待后端回复,如果后端长时间不回复,就给出提示
在请求发送时,跟上面一样类似,只要找到发送的方法里添加setTimeout,在接收方法里取消。
例子:webscoket里的发送方法是:
sendSock(agentData, callback) {
//超时处理,如果对方不回复就超时
this.chaoshi = setTimeout(
e => {
this.loading = false
this.$message({
showClose: true,
message: '发送超时,请重新操作',
type: 'error'
});
}
,30000);
//其他方法
}
webscoket里的接收方法是:
websocketonmessage(revData) { // 数据接收
console.log("接收到的数据:", revData);
//对方回复后,清除超时。
clearTimeout(this.chaoshi);
this.chaoshi = null;
}
附加案例
还有一种加载方式
data{
retrun[
loading:{},
]
}
设置加载
this.loading = this.$loading({
lock: true,
text: '加载中,请稍候...',
spinner: 'el-icon-loading',
background: 'rgba(0, 0, 0, 0.7)'
})
关闭加载,这个你可以在各种场景加,如收到后台数据,就关闭它
this.loading.close()//关闭加载
加载超时,如果没有收到后台数据,也不可能一直加载,超出多久后就超时,利用之前讲得方法,把它们写在一个位置。
this.loading = this.$loading({
lock: true,
text: '加载中,请稍候...',
spinner: 'el-icon-loading',
background: 'rgba(0, 0, 0, 0.7)'
})
//超时就自动取消
this.refreshData = setTimeout(
e => {
this.loading.close(),//关闭加载
//给出超时提示
this.$message({
showClose: true,
message: '加载中,请检查网络或重新操作',
type: 'error'
});
}
,60000)//设置60秒时间
如果没有超时,要记得把超时取消,否则还会弹超时
clearTimeout(this.refreshData);//清除超时
this.refreshData = null;//重置