亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue項(xiàng)目刷新當(dāng)前頁面的三種方式(重載當(dāng)前頁面數(shù)據(jù))

 更新時(shí)間:2023年01月17日 09:46:47   作者:echo丶若夢  
這篇文章主要介紹了vue項(xiàng)目刷新當(dāng)前頁面的三種方式(重載當(dāng)前頁面數(shù)據(jù)),本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

vue項(xiàng)目刷新當(dāng)前頁面的三種方式(重載當(dāng)前頁面數(shù)據(jù))

一、this.$router.go(0)

相當(dāng)于F5刷新,這種方法雖然代碼很少,只有一行,但是體驗(yàn)很差。頁面會(huì)一瞬間的白屏,體驗(yàn)不是很好

二、location.reload()

這種也是一樣,畫面一閃,體驗(yàn)不是很好,相當(dāng)于頁面刷新

推薦解決方法:

三、用provide / inject 組合

原理:允許一個(gè)祖先組件向其所有子孫后代注入一個(gè)依賴,不論組件層次有多深,并在起上下游關(guān)系成立的時(shí)間里始終生效
在App.vue,聲明reload方法,控制router-view的顯示或隱藏,從而控制頁面的再次加載。

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

<script>
export default {
  name: 'App',
  provide () {
    return {
      reload: this.reload
    }
  },
  data () {
    return {
      isRouterAlive: true
    }
  },
  methods: {
    reload () {
      this.isRouterAlive = false
      this.$nextTick(function () {
        this.isRouterAlive = true
      })
    }
  }
}
</script>

在需要用到刷新的頁面。在頁面注入App.vue組件提供(provide)的 reload 依賴,在邏輯完成之后(刪除或添加…),直接this.reload()調(diào)用,即可刷新當(dāng)前頁面。

注入reload方法

export default {
  inject: ['reload'],
 }

在需要重載的地方直接調(diào)用

this.reload()

PS:vue項(xiàng)目刷新當(dāng)前頁面的三種方法

1、最直接整個(gè)頁面重新刷新。

location. reload();
this.$router.go(0);
// 這兩種都可以刷新當(dāng)前頁面的,缺點(diǎn)就是相當(dāng)于按ctrl+F5 強(qiáng)制刷新那種,整個(gè)頁面重新加載,會(huì)出現(xiàn)一個(gè)瞬間的空白頁面,體驗(yàn)不好。

2、新建一個(gè)空白頁面,點(diǎn)擊確定的時(shí)候先跳轉(zhuǎn)到這個(gè)空白頁,然后再立馬跳轉(zhuǎn)回來。這個(gè)方式,相比第一種不會(huì)出現(xiàn)一瞬間的空白頁,只是地址欄有個(gè)快速的切換的過程,也可采用。
3、provide / inject 刷新相對(duì)比較理想。

//首先在app.vue進(jìn)行修改
<template>
    <div id="app">
      // 控制router-view的顯示或隱藏,從而控制頁面的再次加載
      <router-view v-if="isRouterAlive"/>
    </div>
</template>

<script>
export default {
  name: "App",
  provide() {
    return {
      reload : this.reload,
    }
  },
  data() {
    return {
      isRouterAlive:true,
    };
  },
  created(){},
  methods: {
    // 通過聲明reload方法,控制router-view的顯示或隱藏,從而控制頁面的再次加載
    reload(){
      this.isRouterAlive = false;
      this.$nextTick(() => {
        this.isRouterAlive = true;
      })
    },
  },
};
</script>

在需要刷新的頁面引入后直接調(diào)用即可

<template>
  <div>
	<el-button icon="el-icon-refresh" @click="refresh">點(diǎn)擊刷新</el-button>
  </div>
</template>
<script>
export default {
//引用vue reload方法
  inject: ['reload'],
  name:"",
  data() {
	return {
	}
  },
methods: {
    refresh () {
      this.reload()
    }
  }
}
</script>

這樣就實(shí)現(xiàn)了子組件調(diào)取reload方法就實(shí)現(xiàn)了刷新vue組件的功能,而且實(shí)現(xiàn)了組件跨越層級(jí)傳遞數(shù)據(jù)方法。

到此這篇關(guān)于vue項(xiàng)目刷新當(dāng)前頁面的三種方式(重載當(dāng)前頁面數(shù)據(jù))的文章就介紹到這了,更多相關(guān)vue刷新當(dāng)前頁面內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue組件數(shù)據(jù)傳遞與props校驗(yàn)方式

    Vue組件數(shù)據(jù)傳遞與props校驗(yàn)方式

    這篇文章主要介紹了Vue組件數(shù)據(jù)傳遞與props校驗(yàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • 詳解Vue自定義指令及使用

    詳解Vue自定義指令及使用

    這篇文章主要介紹了Vue自定義指令及使用,對(duì)Vue感興趣的同學(xué),可以參考下
    2021-05-05
  • Vue?CompositionAPI中watch和watchEffect的區(qū)別詳解

    Vue?CompositionAPI中watch和watchEffect的區(qū)別詳解

    這篇文章主要為大家詳細(xì)介紹了Vue?CompositionAPI中watch和watchEffect的區(qū)別,文中的示例代碼簡潔易懂,希望對(duì)大家學(xué)習(xí)Vue有一定的幫助
    2023-06-06
  • vue中使用vue-print.js實(shí)現(xiàn)多頁打印

    vue中使用vue-print.js實(shí)現(xiàn)多頁打印

    這篇文章主要介紹了vue中使用vue-print.js實(shí)現(xiàn)多頁打印,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • Vue中的反向代理

    Vue中的反向代理

    這篇文章主要介紹了Vue中的反向代理,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • vue中的h函數(shù)使用及說明

    vue中的h函數(shù)使用及說明

    這篇文章主要介紹了vue中的h函數(shù)使用及說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • 將 vue 生成的 js 上傳到七牛的實(shí)例

    將 vue 生成的 js 上傳到七牛的實(shí)例

    本篇文章主要介紹了將 vue 生成的 js 上傳到七牛的實(shí)例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-07-07
  • vue3中reactive和ref的實(shí)現(xiàn)與區(qū)別詳解

    vue3中reactive和ref的實(shí)現(xiàn)與區(qū)別詳解

    reactive和ref都是vue3實(shí)現(xiàn)響應(yīng)式系統(tǒng)的api,他們是如何實(shí)現(xiàn)響應(yīng)式的呢,reactive和ref又有什么區(qū)別呢,下面小編就來和大家詳細(xì)講講,希望對(duì)大家有所幫助
    2023-10-10
  • 一文帶你了解Vue?和?React的區(qū)別

    一文帶你了解Vue?和?React的區(qū)別

    這篇文章主要介紹了Vue和React的區(qū)別,畢竟是兩個(gè)框架,不像兩個(gè)?API,要說細(xì)節(jié)上的區(qū)別就太多太多了,本文就簡單的帶大家說說Vue?和?React?的區(qū)別,需要的朋友可以參考下
    2023-05-05
  • vue中的data,computed,methods,created,mounted用法及說明

    vue中的data,computed,methods,created,mounted用法及說明

    這篇文章主要介紹了vue中的data,computed,methods,created,mounted用法及說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07

最新評(píng)論