vue 頁面加載進(jìn)度條組件實例
頁面加載進(jìn)度條最初我是在youtube上看到的,后面幾乎在各大網(wǎng)站上都能見到它的身影,可以讓用戶在加載頁面的時候不會對著完全空白的頁面發(fā)呆,提升用戶體驗
但是從開發(fā)角度講,這種進(jìn)度條在真實性上確實很難把握,因為在邏輯代碼加載完成之前,我們都不能統(tǒng)計到進(jìn)度,而邏輯代碼自身的進(jìn)度也無法統(tǒng)計。另外,我們不可能監(jiān)控到所有資源的加載情況。
事實上,用戶并不是在乎你的頁面究竟加載了百分之幾,而真正關(guān)心的是離加載完還有多久,以及這個空白頁面是沒有加載完,還是加載完就是空白的。所以沒我們需要去“模擬”一個進(jìn)度條,在后端數(shù)據(jù)返回前利用一個假的動畫效果模擬加載,在數(shù)據(jù)返回后讀完進(jì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, // 是否顯示進(jìn)度條 val: 0, // 進(jìn)度 } }, props: { /** * 每10毫秒自增幅度 */ step: { type: Number, default: 5, }, /** * 初始值 */ initVal: { type: Number, default: 0, }, /** * 到一定進(jìn)度停止 */ stopVal: { type: Number, default: 80, }, /** * 進(jìn)度條繼續(xù)到成功 */ isOk: { type: Boolean, default: false, }, }, mounted() { // 初始化后加載進(jìn)度,加載到百分之多少由stopVal決定 this.val = this.initVal let step = this.step let timer = setInterval(() => { this.val = this.val + step this.$el.style.width = this.val + '%' // 父組件數(shù)據(jù)加載完前進(jìn)度條最多到stopVal的這個百分值 if (this.val >= this.stopVal) { clearInterval(timer) return } }, 10) }, watch: { /** * 監(jiān)聽組件props變化決定是否繼續(xù)加載,一般在父組件數(shù)據(jù)加載完后改變此標(biāo)志位 */ isOk() { let val = this.val let step = this.step let timer = setInterval(() => { val = val + step this.$el.style.width = val + '%' // 加載到百分百完成 if (val >= 100) { // 關(guān)閉定時器 clearInterval(timer) // 加載完成關(guān)閉進(jìn)度條 this.isShow = false // 加載完成的回調(diào) 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 頁面加載進(jìn)度條組件實例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
uniapp實現(xiàn)省市區(qū)三級級聯(lián)選擇功能(含地區(qū)json文件)
這篇文章主要給大家介紹了關(guān)于uniapp實現(xiàn)省市區(qū)三級級聯(lián)選擇功能(含地區(qū)json文件)的相關(guān)資料,級級聯(lián)是一種常見的網(wǎng)頁交互設(shè)計,用于省市區(qū)選擇,它的目的是方便用戶在一系列選項中進(jìn)行選擇,并且確保所選選項的正確性和完整性,需要的朋友可以參考下2024-06-06關(guān)于antd中select搜索框改變搜索值的問題
這篇文章主要介紹了關(guān)于antd中select搜索框改變搜索值的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04vuecli+AXdownload下載組件封裝?+css3下載懸浮球動畫效果
當(dāng)觸發(fā)下載功能的時候,會觸發(fā)一個下載動畫,下載懸浮球會自動彈出,并且閃爍提示有新的下載任務(wù)直到下載任務(wù)完場提示,接下來通過本文介紹vuecli+AXdownload下載組件封裝?+css3下載懸浮球動畫效果,需要的朋友可以參考下2024-05-05