因为页面需要所以要在调用接口期间加进度条从而让用户可以看到页面加载的进度,之前看到一位大神说从开发角度讲,这种进度条在真实性上确实很难把握,因为在逻辑代码加载完成之前,我们都不能统计到进度,而逻辑代码自身的进度也无法统计。另外,我们不可能监控到所有资源的加载情况。
有的情况下我们可以去让进度条去基本同步我们的加载速度,例如在下载文件时,因为文件相对固定,所以我们可以根据文件的大小去设定进度条的进度步数,但很多情况下我们无法知道其大小,例如调某接口时,接口中的数据时多时少,还有网速的快慢等等原因从而导致我们无法去判断进度条的进度。
而事实上,用户并不是在乎你的页面究竟加载了百分之几,而真正关心的是离加载完还有多久,以及这个空白页面是没有加载完,还是加载完就是空白的。所以没我们需要去“模拟”一个进度条,在后端数据返回前利用一个假的动画效果模拟加载,在数据返回后读完进度条并且隐藏。
首先,我们需要将elementui进度条引入我们所需的位置。
<el-progress :text-inside="true" :stroke-width="24" :percentage="val"
style="margin-top: 10px;" :format="format">
</el-progress>
然后如下所示将需要的数据写入
export default {
data() {
return {
isShow: true, // 是否显示进度条
val: 0, // 进度
}
},
props: {
//每10毫秒自增幅度
step: {
type: Number,
default: 5,
},
//初始值
initVal: {
type: Number,
default: 0,
},
//到一定进度停止
stopVal: {
type: Number,
default: 80,
},
//进度条继续到成功
isOk: {
type: Boolean,
default: false,
},
},
watch: {
//监听组件props变化决定是否继续加载,一般在父组件数据加载完后改变此标志位
isOk() {
let val = this.val
let step = this.step
let timer = setInterval(() => {
val = val + step
this.$el.style.width = val + '%'
// 加载到百分百完成
if (val >= 100) {
// 关闭定时器
clearInterval(timer)
// 加载完成关闭进度条
this.isShow = false
return
}
}, 10)
},
},
mounted() {
//进度条
onProgressFlag:function(){
// 初始化后加载进度,加载到百分之多少由stopVal决定
this.val = this.initVal
let step = this.step
//每500ms执行一次函数(进度条加step=5%)
let timer = setInterval(() => {
// 父组件数据加载完前进度条最多到stopVal的这个百分值
if (this.val >= this.stopVal) {
clearInterval(timer)
return
}
format(percentage) {
if(percentage == 100){
this.onSuccess();
}
},
//调接口处,在this.val = 100; 的时候隐藏进度条组件
},
}
以上就是个人总结,欢迎提问。