欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue使用keep-alive實現(xiàn)組件切換時保存原組件數(shù)據(jù)方法

 更新時間:2020年10月30日 09:52:07   作者:小孬種  
這篇文章主要介紹了vue使用keep-alive實現(xiàn)組件切換時保存原組件數(shù)據(jù)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

前言

最近在做一個精品課程后臺管理系統(tǒng),其中涉及文件上傳和文件列表展示,我不想將他們寫入一個組件,故分開兩個組件實現(xiàn)。

問題:但由于上傳文件需要時間,這時要是用戶切換別的組件查看時,上傳文件組件就銷毀了,導致文件上傳失敗。

追求效果:想利用keep-alive實現(xiàn)上傳組件切換時仍繼續(xù)上傳文件,而其他組件則不會存活。

使用keep-alive的過程

普通方法:直接使用keep-alive

<keep-alive>
 <router-view />
</keep-alive>

效果:雖然能使上傳文件組件存活,在切換組件時仍可繼續(xù)上傳

問題:其余各個組件都不會銷毀和重新掛起,導致所有組件的內(nèi)容不會更新

更好一點的方法:配置路由加以判斷是否適用keep-alive

路由js:

//ManageFiles組件需要重新掛起刷新數(shù)據(jù),而ManageUploadFile為上傳文件組件,故想之存活
{
 path:'files',
 name:'ManageFiles',
 component: () => import('../pages/course/manage/resource/files/Files'),
},
{
 path:'uploadfile',
 name:'ManageUploadFile',
 meta:{
 keepAlive:true  //是否存活標志
 },
 component: () => import('../pages/course/manage/resource/files/UploadFile'),
},

切換組件:

<template>
 <div class="manageResource">
 <keep-alive>
  <router-view v-if="$route.meta.keepAlive" />
 </keep-alive>
 <router-view v-if="!$route.meta.keepAlive" />
 </div>
</template>

效果圖:

(1)一開始為File組件,mounted()打印'我是File'

(2)第一次切換為UploadFile組件,mounted()打印'我是UploadFile'

(3)再次切換回File組件,mounted()再次重新打印'我是File'

(4)最后再次切換回UploadFile組件,因為它一直存活,所以不會重新觸發(fā)mounted()再次重新打印'我是UploadFile'

補充知識:vue 動態(tài)組件(tabs切換)keep-alive:主要用于保留組件狀態(tài)或避免重新渲染

通過keep-alive 保留數(shù)據(jù)值 填寫數(shù)據(jù)時切換到其他頁面,后返回當前頁數(shù)據(jù)保留 ,主要用于保留組件狀態(tài)或避免重新渲染

 <!--動態(tài)組件-component使用-->
 <div class="app">
 <ul>
 <li @click="currView='home'">首頁</li>
 <li @click="currView='abount'">關(guān)于我們</li>
 </ul>
 <!--通過keep-alive 保留數(shù)據(jù)值 填寫數(shù)據(jù)時切換到其他頁面,后返回當前頁數(shù)據(jù)保留-->
 <keep-alive>
 <component :is="currView"></component>
 </keep-alive>
 </div>
<script type="text/x-Template" id="homeTemp">
  <h2>首頁數(shù)據(jù)</h2>
</script>
<script type="text/x-Template" id="abountTemp">
  <h2>關(guān)于我們數(shù)據(jù)<input type="text"/></h2>
</script>
<script type="text/javascript">
 var vm=new Vue({
 el:'.app',
 data:{
  currView:"home"
 },
 components:{
  "home":{
   template:"#homeTemp"
  },
  "abount":{
  template:"#abountTemp"
  }
 }
 });
 
</script>

以上這篇vue使用keep-alive實現(xiàn)組件切換時保存原組件數(shù)據(jù)方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Element-Plus Select組件實現(xiàn)滾動分頁加載功能

    Element-Plus Select組件實現(xiàn)滾動分頁加載功能

    Element-Plus的select組件并沒有自帶滾動分頁加載的功能,其雖然提供了自定義下拉菜單的底部的方式可以自定義上一頁及下一頁操作按鈕的方式進行分頁加載切換,這篇文章主要介紹了Element-Plus Select組件實現(xiàn)滾動分頁加載功能,需要的朋友可以參考下
    2024-03-03
  • vue雙向數(shù)據(jù)綁定原理探究(附demo)

    vue雙向數(shù)據(jù)綁定原理探究(附demo)

    本文主要介紹了vue雙向數(shù)據(jù)綁定的原理,文章結(jié)尾附上完整demo下載。具有一定的參考價值,下面跟著小編一起來看下吧
    2017-01-01
  • vue3使用Element-plus的el-pagination分頁組件時無法顯示中文

    vue3使用Element-plus的el-pagination分頁組件時無法顯示中文

    本文主要介紹了vue3使用Element-plus的el-pagination分頁組件時無法顯示中文,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-12-12
  • element?upload?鉤子函數(shù)的坑及解決

    element?upload?鉤子函數(shù)的坑及解決

    這篇文章主要介紹了element?upload?鉤子函數(shù)的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • Vue.js實現(xiàn)網(wǎng)格列表布局轉(zhuǎn)換方法

    Vue.js實現(xiàn)網(wǎng)格列表布局轉(zhuǎn)換方法

    下面小編就為大家?guī)硪黄猇ue.js實現(xiàn)網(wǎng)格列表布局轉(zhuǎn)換方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • 詳解vue中axios封裝與api接口封裝管理

    詳解vue中axios封裝與api接口封裝管理

    axios的封裝和api接口的統(tǒng)一管理,其實主要目的就是在幫助我們簡化代碼和利于后期的更新維護,在vue項目中,和后臺交互獲取數(shù)據(jù)這塊,我們通常使用的是axios庫,本文就給大家介紹一下axios封裝與api接口封裝管理,需要的朋友可以參考下
    2023-06-06
  • vue 項目如何引入微信sdk接口的方法

    vue 項目如何引入微信sdk接口的方法

    本篇文章主要介紹了vue 項目如何引入微信sdk接口的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-12
  • vue.js Router嵌套路由

    vue.js Router嵌套路由

    這篇文章主要介紹vue.js Router嵌套路由,平時訪問首頁,里面有新聞類的/home/news,還有信息類的/home/message這時候就需要使用到嵌套路由,下面我們就來具體學習嵌套路由的原理,需要的朋友可以參考一下
    2021-10-10
  • vue項目安裝scss常見報錯處理方式

    vue項目安裝scss常見報錯處理方式

    這篇文章主要介紹了vue項目安裝scss常見報錯處理方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue在標簽中如何使用(data-XXX)自定義屬性并獲取

    vue在標簽中如何使用(data-XXX)自定義屬性并獲取

    這篇文章主要介紹了vue在標簽中如何使用(data-XXX)自定義屬性并獲取,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08

最新評論