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

vue組件 keep-alive 和 transition 使用詳解

 更新時間:2019年10月11日 09:25:29   作者:℡鞋子~特大號  
這篇文章主要介紹了vue組件 keep-alive 和 transition 使用詳解,需要的朋友可以參考下

1.keep-alive

能在組件切換過程中將狀態(tài)保留在內(nèi)存中,防止重復(fù)渲染DOM。

包裹動態(tài)組件時,會緩存不活動的組件實例,而不是銷毀它們。和 相似, 是一個抽象組件:它自身不會渲染一個 DOM 元素,也不會出現(xiàn)在父組件鏈中。

當(dāng)組件在 內(nèi)被切換,它的 activated 和 deactivated 這兩個生命周期鉤子函數(shù)將會被對應(yīng)執(zhí)行。

include: 字符串或正則表達(dá)式。只有匹配的組件會被緩存。
exclude: 字符串或正則表達(dá)式。任何匹配的組件都不會被緩存。

// 組件

export default {
 name: 'test-keep-alive',
 data () {
  return {
    includedComponents: "test-keep-alive"     //這句不能漏掉
  }
 }
}

<keep-alive include="test-keep-alive">
 <!-- 將緩存name為test-keep-alive的組件 -->
 <component></component>
</keep-alive>

<keep-alive include="a,b"> 
<!-- 將緩存name為a或者b的組件,結(jié)合動態(tài)組件使用 --> 
  <component :is="view"></component> 
</keep-alive> 
<!-- 使用正則表達(dá)式,需使用v-bind --> 
<keep-alive :include="/a|b/"> 
  <component :is="view"></component> 
</keep-alive>

結(jié)合router使用

這一段通常放在vue項目最外層的app.vue中 為了使所有組件都能很好的利用 這個是否需要緩存特性

//需要緩存時
<keep-alive>
  <router-view v-if="$route.meta.keepAlive"></router-view>
</keep-alive>
//不需要緩存時
<router-view v-if="!$route.meta.keepAlive"></router-view>
//兩組同時啟用,只要在路由meta元信息中 對keepAlive定義,就能自主控制是否需要緩存

//...router.js
export default new Router({
 routes: [
  {
   path: '/',
   name: 'Hello',
   component: Hello,
   meta: {
    keepAlive: false // 不需要緩存
   }
  },
  {
   path: '/page1',
   name: 'Page1',
   component: Page1,
   meta: {
    keepAlive: true // 需要被緩存
   }
  }
 ]
})

2.transition

name - string,用于自動生成 CSS 過渡類名。例如:name: ‘fade' 將自動拓展為.fade-enter,.fade-enter-active等。默認(rèn)類名為 “v”

元素作為單個元素/組件的過渡效果。 只會把過渡效果應(yīng)用到其包裹的內(nèi)容上,而不會額外渲染 DOM 元素,也不會出現(xiàn)在檢測過的組件層級中。

Vue只有在插入,更新或者移除DOM元素時才會應(yīng)用過渡效果。一般兩類情況一個是利用CSS過渡或者動畫,另一個是利用JavaScript鉤子函數(shù)。

!-- 首先將要過渡的元素用transition包裹,并設(shè)置過渡的name,然后添加觸發(fā)這個元素過渡的按鈕(實際項目中不一定是按鈕,任何能觸發(fā)過渡組件的DOM操作的操作都可以) -->

<div>
 <button @click="show=!show">show</button>
 <transition name="fade">
  <p v-show="show">hello</p>
 </transition>
</div>

&.fade-enter-active, &.fade-leave-active
 transition: all 0.5s ease   
&.fade-enter, &.fade-leave-active
 opacity: 0 

組件過渡過程中,會有四個CSS類名進(jìn)行切換,這四個類名與上面transition的name屬性有關(guān),比如name=“fade”,會有如下四個CSS類名:

fade-enter:進(jìn)入過渡的開始狀態(tài),元素被插入時生效,只應(yīng)用一幀后立即刪除;

fade-enter-active:進(jìn)入過渡的結(jié)束狀態(tài),元素被插入時就生效,在過渡過程完成之后移除;

fade-leave:離開過渡的開始狀態(tài),元素被刪除時觸發(fā),只應(yīng)用一幀后立即刪除;

fade-leave-active:離開過渡的結(jié)束狀態(tài),元素被刪除時生效,離開過渡完成之后被刪除;

從上面四個類名可以看出,fade-enter-activefade-leave-active在整個進(jìn)入或離開過程中都有效,所以CSS的transition屬性在這兩個類下進(jìn)行設(shè)置。

上面示例中,fade-enter和fade-leave-active類設(shè)置CSS為opacity:0,說明過渡剛進(jìn)入和離開的時候透明度為0,即不顯示。當(dāng)然還可以設(shè)置其他的CSS屬性

總結(jié)

以上所述是小編給大家介紹的vue組件 keep-alive 和 transition 使用詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章

  • vue中4個自定義指令講解及實例用法

    vue中4個自定義指令講解及實例用法

    在本篇文章里小編給大家整理了一篇關(guān)于vue中4個自定義指令講解及實例用法,有興趣的朋友們可以跟著學(xué)習(xí)下。
    2021-12-12
  • Vue中的百度地圖定位BMap.GeolocationControl的用法

    Vue中的百度地圖定位BMap.GeolocationControl的用法

    BMap.GeolocationControl?是百度地圖API中的一個類,用于添加地理定位控件到地圖上,以便用戶可以通過該控件獲取自己的當(dāng)前位置,本文給大家介紹Vue中的百度地圖定位BMap.GeolocationControl的用法,感興趣的朋友跟隨小編一起看看吧
    2023-10-10
  • vue2.0 常用的 UI 庫實例講解

    vue2.0 常用的 UI 庫實例講解

    這篇文章主要介紹了vue2.0 常用的 UI 庫實例講解,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-12-12
  • vue項目中實現(xiàn)緩存的最佳方案詳解

    vue項目中實現(xiàn)緩存的最佳方案詳解

    這篇文章主要給大家介紹了關(guān)于vue項目中實現(xiàn)緩存的最佳方案,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用vue具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • Vue的filters(本地)或filter(全局)過濾常用數(shù)據(jù)類型解析

    Vue的filters(本地)或filter(全局)過濾常用數(shù)據(jù)類型解析

    這篇文章主要介紹了Vue的filters(本地)或filter(全局)過濾常用數(shù)據(jù)類型,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • vue實現(xiàn)移動端拖動排序

    vue實現(xiàn)移動端拖動排序

    這篇文章主要為大家詳細(xì)介紹了vue實現(xiàn)移動端拖動排序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • Vue中用watch一次監(jiān)聽多個值變化的示例詳解

    Vue中用watch一次監(jiān)聽多個值變化的示例詳解

    在Vue中,watch 本身不能監(jiān)聽多個變量,但我們可以通過返回具有計算屬性的對象然后監(jiān)聽該對象,從而實現(xiàn)一次性“監(jiān)聽多個變量”,本文給大家介紹了Vue中用watch一次監(jiān)聽兩個值變化的示例,需要的朋友可以參考下
    2024-01-01
  • vue動態(tài)修改頁面title的兩種方法

    vue動態(tài)修改頁面title的兩種方法

    本文主要介紹了vue動態(tài)修改頁面title的兩種方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • vue 中Virtual Dom被創(chuàng)建的方法

    vue 中Virtual Dom被創(chuàng)建的方法

    本文將通過解讀render函數(shù)的源碼,來分析vue中的vNode是如何創(chuàng)建的,本文通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-04-04
  • vue eslint簡要配置教程詳解

    vue eslint簡要配置教程詳解

    這篇文章主要介紹了vue eslint簡要配置,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-07-07

最新評論