首頁 >web前端 >Vue.js >帶你詳解vue中實現全頁或局部刷新的方法

帶你詳解vue中實現全頁或局部刷新的方法

青灯夜游
青灯夜游轉載
2021-12-29 19:23:167731瀏覽

vue中怎麼實現頁面刷新?以下這篇文章為大家介紹一下在vue中實現全頁刷新和局部刷新的方法,希望對大家有幫助!

帶你詳解vue中實現全頁或局部刷新的方法

一.全頁刷新

1.修改App.vue,程式碼如下:

<template>
  <div id="app">
    <router-view v-if="isRouterAlive" />
  </div>
</template>

<script>
export default {
  name: &#39;App&#39;,
  provide() { // 父组件中返回要传给下级的数据
    return {
      reload: this.reload
    }
  },
  data() {
    return {
      isRouterAlive: true
    }
  },
  methods: {
    reload() {
      this.isRouterAlive = false
      this.$nextTick(function() {
        this.isRouterAlive = true
      })
    }
  }
}
</script>

重點如下圖所示:

帶你詳解vue中實現全頁或局部刷新的方法

2.到需要刷新的頁面使用inject 進行導入並引用reload:

帶你詳解vue中實現全頁或局部刷新的方法

3.在需要進行調用的方法中呼叫this.reload() 即可

帶你詳解vue中實現全頁或局部刷新的方法

二、局部刷新

1.定義一個變數isReloadData,並將該變數綁定到需要刷新的標籤上:

帶你詳解vue中實現全頁或局部刷新的方法

帶你詳解vue中實現全頁或局部刷新的方法

#2.定義局部刷新的方法reloadPart:

帶你詳解vue中實現全頁或局部刷新的方法

3.在需要執行局部刷新的方法中進行呼叫

帶你詳解vue中實現全頁或局部刷新的方法

#三、應用程式場景

  • 當在頁面中動態修改了某些數據,或者是props 帶過來的數據,又或者是透過funcation 動態設定的屬性,可能在修改之後不會展示最新的數據。
  • 當頁面資料發生了變化,但是頁面渲染會出現bug,例如 el-table 元件在資料發生變化後,就會出現一個空白區域。

此時,全頁面刷新或局部刷新就會派上用場,下面截圖舉例本人遇到的第二種情況,已透過使用全頁刷新及局部刷新解決:

1.預設全選,頁面渲染正常:

帶你詳解vue中實現全頁或局部刷新的方法

2.勾選掉一個展示列,頁面渲染正常:

帶你詳解vue中實現全頁或局部刷新的方法

3.把勾選掉的展示列再勾選上,出現空白區域:

帶你詳解vue中實現全頁或局部刷新的方法

#此時,只需要在單選的方法中調用局部刷新的方法this.reloadPart() 即可解決,同理,全選也是如此。

4.當每次新增展示列時,表格也會出現空白區域,此時我們只需要在新增記錄成功後呼叫全頁面刷新的方法 this.reload() 即可。

【相關推薦:《vue.js教學》】

以上是帶你詳解vue中實現全頁或局部刷新的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:juejin.cn。如有侵權,請聯絡admin@php.cn刪除