当前位置: 首页>編程日記>正文

Vue 动态组件component

Vue 动态组件component

有的时候,在不同组件之间进行动态切换是非常有用的。即页面的某个位置要显示的组件是不确定的,是会变化的。多个组件每次只显示一个并且动态的进行切换

场景:局部的小的那种选项卡

语法:

在页面想显示我们多个组件的时候会用下面的语法 来声明挂载点

 <component :is="你具体要显示那个组件的变量"> </component>方法实现

首先在components里先来三个组件(内容随便写)

 然后比如想在Home页面用

<template><div>Home页面<button @click="fun('One')">点我去one</button><button @click="fun('Two')">点我去two</button><button @click="fun('Three')">点我去three</button><component :is="com"></component></div>
</template><script>
import One from "@/components/one.vue"
import Two from "@/components/two.vue"
import Three from "@/components/three.vue"
export default {data(){return {com:"Three"}},methods:{fun(data){this.com = data}},components:{One,Two,Three}
}
</script>

记住一句话:多个组件使用同一个挂载点并且动态切换

思考

动态组件中如果有多个输入框 那么我们在切换动态组件的时候会发现这些驶入框的内容会丢失

多个路由页面中如果有多个输入框 那么我们在切换路由页面的时候会发现这些驶入框的内容也会丢失

我们在路由或者是动态组件切换的时候,因为每次切换vue都会创建一个新的vue组件实例,所以会丢失

keep-alive

可以在keep-alive包裹的内容,在切换的时候把数据状态保存在内存中,防止重复的DOM渲染 减少了性能与时间上的损耗

比如:用在动态组件之上

 <keep-alive><component :is="com"></component></keep-alive>

用在路由之上只需包裹路由的出口

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

动态组件的属性

include 你想缓存谁 (比如我想缓存One)

 <keep-alive  include="One"><component :is="com"></component></keep-alive>

可以写多个中间用逗号隔开

<keep-alive  include="One,Two"><component :is="com"></component>
</keep-alive>

exclude 你不想缓存谁(我不想缓存One和Two)

<keep-alive  exclude="One,Two"><component :is="com"></component>
</keep-alive>

其中exclude的优先级比include高

动态组件的钩子函数

有两个钩子函数 但是在写的时候一定要在被keep-alive所管理的组件中进行使用

activated 进入到被keep-alive管理的组件时候触发

deactivated 离开被keep-alive管理的组件时候触发

<script>export default {activated(){console.log("进入到keep-alive管理的组件了")},deactivated(){console.log("离开了keep-alive管理的组件了")}}
</script>


https://www.fengoutiyan.com/post/14528.html

相关文章:

  • su动态组件有什么用
  • react动态组件
  • vue component
  • su动态组件
  • vue 动态组件
  • vue异步组件
  • 动态组件
  • component的父类
  • 鏡像模式如何設置在哪,圖片鏡像操作
  • 什么軟件可以把圖片鏡像翻轉,C#圖片處理 解決左右鏡像相反(旋轉圖片)
  • 手機照片鏡像翻轉,C#圖像鏡像
  • 視頻鏡像翻轉軟件,python圖片鏡像翻轉_python中鏡像實現方法
  • 什么軟件可以把圖片鏡像翻轉,利用PS實現圖片的鏡像處理
  • 照片鏡像翻轉app,java實現圖片鏡像翻轉
  • 什么軟件可以把圖片鏡像翻轉,python圖片鏡像翻轉_python圖像處理之鏡像實現方法
  • matlab下載,matlab如何鏡像處理圖片,matlab實現圖像鏡像
  • 圖片鏡像翻轉,MATLAB:鏡像圖片
  • 鏡像翻轉圖片的軟件,圖像處理:實現圖片鏡像(基于python)
  • canvas可畫,JavaScript - canvas - 鏡像圖片
  • 圖片鏡像翻轉,UGUI優化:使用鏡像圖片
  • Codeforces,CodeForces 1253C
  • MySQL下載安裝,Mysql ERROR: 1253 解決方法
  • 勝利大逃亡英雄逃亡方案,HDU - 1253 勝利大逃亡 BFS
  • 大一c語言期末考試試題及答案匯總,電大計算機C語言1253,1253《C語言程序設計》電大期末精彩試題及其問題詳解
  • lu求解線性方程組,P1253 [yLOI2018] 扶蘇的問題 (線段樹)
  • c語言程序設計基礎題庫,1253號C語言程序設計試題,2016年1月試卷號1253C語言程序設計A.pdf
  • 信奧賽一本通官網,【信奧賽一本通】1253:抓住那頭牛(詳細代碼)
  • c語言程序設計1253,1253c語言程序設計a(2010年1月)
  • 勝利大逃亡英雄逃亡方案,BFS——1253 勝利大逃亡
  • 直流電壓測量模塊,IM1253B交直流電能計量模塊(艾銳達光電)
  • c語言程序設計第三版課后答案,【渝粵題庫】國家開放大學2021春1253C語言程序設計答案
  • 18轉換為二進制,1253. 將數字轉換為16進制
  • light-emitting diode,LightOJ-1253 Misere Nim
  • masterroyale魔改版,1253 Dungeon Master
  • codeformer官網中文版,codeforces.1253 B
  • c語言程序設計考研真題及答案,2020C語言程序設計1253,1253計算機科學與技術專業C語言程序設計A科目2020年09月國家開 放大學(中央廣播電視大學)
  • c語言程序設計基礎題庫,1253本科2016c語言程序設計試題,1253電大《C語言程序設計A》試題和答案200901
  • 肇事逃逸車輛無法聯系到車主怎么辦,1253尋找肇事司機