91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue頁面加載進度條組件

發布時間:2021-06-30 14:47:59 來源:億速云 閱讀:518 作者:小新 欄目:web開發

小編給大家分享一下vue頁面加載進度條組件,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

頁面加載進度條最初我是在youtube上看到的,后面幾乎在各大網站上都能見到它的身影,可以讓用戶在加載頁面的時候不會對著完全空白的頁面發呆,提升用戶體驗

但是從開發角度講,這種進度條在真實性上確實很難把握,因為在邏輯代碼加載完成之前,我們都不能統計到進度,而邏輯代碼自身的進度也無法統計。另外,我們不可能監控到所有資源的加載情況。

事實上,用戶并不是在乎你的頁面究竟加載了百分之幾,而真正關心的是離加載完還有多久,以及這個空白頁面是沒有加載完,還是加載完就是空白的。所以沒我們需要去“模擬”一個進度條,在后端數據返回前利用一個假的動畫效果模擬加載,在數據返回后讀完進度條并且隱藏。

// 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,
  },
  /**
  * 進度條繼續到成功
  */
  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: {
  /**
  * 監聽組件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
   // 加載完成的回調
   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頁面加載進度條組件”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

海口市| 灌南县| 邹城市| 谢通门县| 齐齐哈尔市| 隆林| 岑巩县| 友谊县| 定西市| 颍上县| 蒙自县| 固镇县| 汝阳县| 同心县| 承德县| 淅川县| 聂拉木县| 金平| 洞头县| 西华县| 鹤壁市| 武鸣县| 丽江市| 古蔺县| 彭山县| 确山县| 灵丘县| 观塘区| 修文县| 公安县| 曲麻莱县| 揭阳市| 苏州市| 德格县| 招远市| 徐水县| 安陆市| 浪卡子县| 哈尔滨市| 乐清市| 社旗县|