vue+elementui中进度条组件应用写法_在vue中如何实现页面加载进度条组件

        因为页面需要所以要在调用接口期间加进度条从而让用户可以看到页面加载的进度,之前看到一位大神说从开发角度讲,这种进度条在真实性上确实很难把握,因为在逻辑代码加载完成之前,我们都不能统计到进度,而逻辑代码自身的进度也无法统计。另外,我们不可能监控到所有资源的加载情况。

        有的情况下我们可以去让进度条去基本同步我们的加载速度,例如在下载文件时,因为文件相对固定,所以我们可以根据文件的大小去设定进度条的进度步数,但很多情况下我们无法知道其大小,例如调某接口时,接口中的数据时多时少,还有网速的快慢等等原因从而导致我们无法去判断进度条的进度。

        而事实上,用户并不是在乎你的页面究竟加载了百分之几,而真正关心的是离加载完还有多久,以及这个空白页面是没有加载完,还是加载完就是空白的。所以没我们需要去“模拟”一个进度条,在后端数据返回前利用一个假的动画效果模拟加载,在数据返回后读完进度条并且隐藏。

首先,我们需要将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; 的时候隐藏进度条组件
    },
}

以上就是个人总结,欢迎提问。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值