日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > vue >内容正文

vue

vue使用provide / inject 组合刷新页面+单独组件刷新

發布時間:2024/3/13 vue 44 豆豆
生活随笔 收集整理的這篇文章主要介紹了 vue使用provide / inject 组合刷新页面+单独组件刷新 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

原文鏈接:https://www.cnblogs.com/leng12/p/xiaoleng.html

一、this.$router.go(0)
相當于F5刷新,這種方法雖然代碼很少,只有一行,但是體驗很差。頁面會一瞬間的白屏,體驗不是很好;

二、location.reload()
這種也是一樣,畫面一閃,體驗不是很好,相當于頁面刷新

推薦解決方法:
三、用provide / inject 組合

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

App.vue
在App.vue頁面聲明

<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 = falsethis.$nextTick(function () {this.isRouterAlive = true})}} } </script>

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

頁面中引用

export default {inject:['reload'],methods:{update(){// 在需要用到的事件中調用this.reload();函數即可this.reload() } } }

原文鏈接:https://www.cnblogs.com/leng12/p/xiaoleng.html

單獨組件刷新

開發過程中會遇到一個頁面多個組件,特定條件下,我只想刷新單個組件,不要整個頁面重載怎么辦。
使用v-if指令:如果是刷新某個子組件,則可以通過v-if指令實現。我們知道,當v-if的值發生變化時,組件都會被重新渲染一遍。因此,利用v-if指令的特性,可以達到強制刷新組件的目的。

<Icon type="md-refresh" @click="refreshPage" /> <OrderInfo v-if="isShow"></OrderInfo> export default {data(){isShow:true},method:{refreshPage(){ // 單獨刷新頁面console.log("刷新”");this.isShow = false;this.$nextTick(() => {this.isShow = true;})}} }

總結:頁面的刷新分為三步
1、app.vue頁面中注入App.vue組件提供(provide)的 reload 依賴
2、頁面引用 inject:['reload']
3、將需要刷新的部分綁定 v-if

組件刷新使用vue特性v-if綁定值發生改變頁面刷新
1、給組件綁定v-if
2、更改v-if綁定值,使用$nextTick再修改

$nextTick講解:https://vue3js.cn/interview/vue/nexttick.html#%E4%B8%80%E3%80%81nexttick%E6%98%AF%E4%BB%80%E4%B9%88

總結

以上是生活随笔為你收集整理的vue使用provide / inject 组合刷新页面+单独组件刷新的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。