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

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

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

前言

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

問(wèn)題:但由于上傳文件需要時(shí)間,這時(shí)要是用戶(hù)切換別的組件查看時(shí),上傳文件組件就銷(xiāo)毀了,導(dǎo)致文件上傳失敗。

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

使用keep-alive的過(guò)程

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

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

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

問(wèn)題:其余各個(gè)組件都不會(huì)銷(xiāo)毀和重新掛起,導(dǎo)致所有組件的內(nèi)容不會(huì)更新

更好一點(diǎn)的方法:配置路由加以判斷是否適用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  //是否存活標(biāo)志
 },
 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)一開(kāi)始為File組件,mounted()打印'我是File'

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

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

(4)最后再次切換回UploadFile組件,因?yàn)樗恢贝婊?,所以不?huì)重新觸發(fā)mounted()再次重新打印'我是UploadFile'

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

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

 <!--動(dòng)態(tài)組件-component使用-->
 <div class="app">
 <ul>
 <li @click="currView='home'">首頁(yè)</li>
 <li @click="currView='abount'">關(guān)于我們</li>
 </ul>
 <!--通過(guò)keep-alive 保留數(shù)據(jù)值 填寫(xiě)數(shù)據(jù)時(shí)切換到其他頁(yè)面,后返回當(dāng)前頁(yè)數(shù)據(jù)保留-->
 <keep-alive>
 <component :is="currView"></component>
 </keep-alive>
 </div>
<script type="text/x-Template" id="homeTemp">
  <h2>首頁(yè)數(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實(shí)現(xiàn)組件切換時(shí)保存原組件數(shù)據(jù)方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Element-Plus Select組件實(shí)現(xiàn)滾動(dòng)分頁(yè)加載功能

    Element-Plus Select組件實(shí)現(xiàn)滾動(dòng)分頁(yè)加載功能

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

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

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

    vue3使用Element-plus的el-pagination分頁(yè)組件時(shí)無(wú)法顯示中文

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

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

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

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

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

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

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

    vue 項(xiàng)目如何引入微信sdk接口的方法

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

    vue.js Router嵌套路由

    這篇文章主要介紹vue.js Router嵌套路由,平時(shí)訪問(wèn)首頁(yè),里面有新聞?lì)惖?home/news,還有信息類(lèi)的/home/message這時(shí)候就需要使用到嵌套路由,下面我們就來(lái)具體學(xué)習(xí)嵌套路由的原理,需要的朋友可以參考一下
    2021-10-10
  • vue項(xiàng)目安裝scss常見(jiàn)報(bào)錯(cuò)處理方式

    vue項(xiàng)目安裝scss常見(jiàn)報(bào)錯(cuò)處理方式

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

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

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

最新評(píng)論