vue 頁面加載進度條組件實例
頁面加載進度條最初我是在youtube上看到的,后面幾乎在各大網站上都能見到它的身影,可以讓用戶在加載頁面的時候不會對著完全空白的頁面發(fā)呆,提升用戶體驗
但是從開發(fā)角度講,這種進度條在真實性上確實很難把握,因為在邏輯代碼加載完成之前,我們都不能統(tǒng)計到進度,而邏輯代碼自身的進度也無法統(tǒng)計。另外,我們不可能監(jiān)控到所有資源的加載情況。
事實上,用戶并不是在乎你的頁面究竟加載了百分之幾,而真正關心的是離加載完還有多久,以及這個空白頁面是沒有加載完,還是加載完就是空白的。所以沒我們需要去“模擬”一個進度條,在后端數據返回前利用一個假的動畫效果模擬加載,在數據返回后讀完進度條并且隱藏。
// progress-bar.vue
<template>
<transition name="fade">
<div class="progress-bar" v-if="isShow">
</div>
</transition>
</template>
<script type="text/babel">
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,
},
/**
* 進度條繼續(xù)到成功
*/
isOk: {
type: Boolean,
default: false,
},
},
mounted() {
// 初始化后加載進度,加載到百分之多少由stopVal決定
this.val = this.initVal
let step = this.step
let timer = setInterval(() => {
this.val = this.val + step
this.$el.style.width = this.val + '%'
// 父組件數據加載完前進度條最多到stopVal的這個百分值
if (this.val >= this.stopVal) {
clearInterval(timer)
return
}
}, 10)
},
watch: {
/**
* 監(jiān)聽組件props變化決定是否繼續(xù)加載,一般在父組件數據加載完后改變此標志位
*/
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
// 加載完成的回調
this.$emit('callback', 'load success')
return
}
}, 10)
},
},
}
</script>
<style lang="stylus" rel="stylesheet/stylus">
.progress-bar {
position fixed
top 0
height 6px
width 0
background-color #999
}
.fade {
&-enter-active, &-leave-active {
transition: all .3s
}
&-enter, &-leave-active {
opacity: 0
}
}
</style>
以上這篇vue 頁面加載進度條組件實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
uniapp實現省市區(qū)三級級聯(lián)選擇功能(含地區(qū)json文件)
這篇文章主要給大家介紹了關于uniapp實現省市區(qū)三級級聯(lián)選擇功能(含地區(qū)json文件)的相關資料,級級聯(lián)是一種常見的網頁交互設計,用于省市區(qū)選擇,它的目的是方便用戶在一系列選項中進行選擇,并且確保所選選項的正確性和完整性,需要的朋友可以參考下2024-06-06
vuecli+AXdownload下載組件封裝?+css3下載懸浮球動畫效果
當觸發(fā)下載功能的時候,會觸發(fā)一個下載動畫,下載懸浮球會自動彈出,并且閃爍提示有新的下載任務直到下載任務完場提示,接下來通過本文介紹vuecli+AXdownload下載組件封裝?+css3下載懸浮球動畫效果,需要的朋友可以參考下2024-05-05

