第十单元(动态组件 keep-alive(钩子函数) 递归组件(name) 组件命名约定)

#课程目标

  1. 熟练掌握动态组件的实现
  2. 掌握keep-alive缓存组件,以及相应的钩子函数
  3. 熟练掌握递归组件,以及递归组件的实现原理
  4. 了解组件的命名约定

#知识点

#1.动态组件

​ 首先得明白什么叫做动态组件,让多个组件使用同一个挂载点,并动态切换,这就是动态组件。

#1.1<component>元素

在vue中,可以通过使用保留的 <component> 元素,动态地绑定到它的 is 特性,可以实现动态组件

<template>
<div>
<button @click="change">切换页面</button>
<!--保留component元素 使用is显示相应的组件 实现动态组件-->
<component :is="currentView"></component>
</div>
</template>
<script>
import Aa from '@/components/Aa'
import Bb from '@/components/Bb'
export default {
name: 'Index',
data () {
return {
index:0,
//将组件放进数组中
arr:[Aa,Bb],
}
},
methods:{
change(){
//改变index的值,在0和1中来回切换
this.index = (++this.index)%2;
}
},
computed:{
//返回当前显示的数组
currentView(){
return this.arr[this.index];
}
}
}
</script>
 
#1.2动态组件的缓存(<keep-alive>  )

<keep-alive> 包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们。和 <transition> 相似,<keep-alive> 是一个抽象组件:它自身不会渲染一个 DOM 元素,也不会出现在父组件链中

基础用法

<template>
<div>
<button @click="change">切换页面</button>
<!--keep-alive的使用方式,直接包在组件外面即可,里面的组件即可实现组件缓存-->
<keep-alive>
<!--保留component元素 使用is显示相应的组件 实现动态组件-->
<component :is="currentView"></component>
</keep-alive>
</div>
</template>
<script>
import Aa from '@/components/Aa'
import Bb from '@/components/Bb'
export default {
name: 'Index',
data () {
return {
index:0,
//将组件放进数组中
arr:[Aa,Bb],
}
},
methods:{
change(){
//改变index的值,在0和1中来回切换
this.index = (++this.index)%2;
}
},
computed:{
//返回当前显示的数组
currentView(){
return this.arr[this.index];
}
}
}
</script>
 

注意:既然是缓存,那么重新切换组件时,组件中相应的vue的生命周期函数,将不会再被触发(如:beforeCreate,created,beforeMount,mounted,beforeUpdate,updated,beforeDestroy,destroyed)

keep-alive元素中最后渲染的结果是,要求同时只有一个子元素被渲染(只能有一个根组件,和template元素类似),所以,我们也可以在keep-alive元素中写v-if判断组件的显示和隐藏:

<template>
<div>
<button @click="change">切换页面</button>
<!--keep-alive的使用方式,直接包在组件外面即可,里面的组件即可实现组件缓存-->
<keep-alive>
<Aa v-if="index==0"></Aa>
<Bb v-if="index==1"></Bb>
</keep-alive>
</div>
</template>
<script>
import Aa from '@/components/Aa'
import Bb from '@/components/Bb'
export default {
name: 'Index',
data () {
return {
index:0,
//将组件放进数组中
arr:[Aa,Bb],
}
},
methods:{
change(){
//改变index的值,在0和1中来回切换
this.index = (++this.index)%2;
}
},
components:{
Aa,Bb
}
}
}
</script>
 
#1.3 缓存组件中的钩子函数activated 和 deactivated

activated 和 deactivated 在 <keep-alive> 树内的所有嵌套组件中触发

activated===>这个函数是在组件被切换显示的时候,触发该函数

deactivated===>这个函数是在组件被切换隐藏的时候,触发该函数

//Aa.vue组件  当这个组件显示或者隐藏时  会触发activated或者deactivated
<template>
<div>
{{msg}}
</div>
</template> <script>
export default {
name: 'Aa',
data () {
return {
msg:'我是Aa'
}
},
//显示时触发该函数
activated(){
console.log('a来了')
},
//隐藏时触发该函数
deactivated(){
console.log('a走了')
}
}
</script>
 
#1.4组件有条件地缓存 includeexclude
  • include和 exclude属性允许组件有条件地缓存,见语义化命名,就知道前者是包含,后者则是排除。
  • 二者都可以用逗号分隔字符串、正则表达式或一个数组来表示 。
  • 匹配首先检查组件自身的 name 选项,如果 name 选项不可用,则匹配它的局部注册名称(父组件 components 选项的键值)。
  • 匿名组件不能被匹配。
<!-- 逗号分隔字符串 -->
<keep-alive include="Aa">
<Aa v-if="index==0"></Aa>
<Bb v-if="index==1"></Bb>
</keep-alive> <!-- 正则表达式 (使用 v-bind) -->
<keep-alive :include="/Aa|Bb/">
<Aa v-if="index==0"></Aa>
<Bb v-if="index==1"></Bb>
</keep-alive> <!-- 数组 (使用 v-bind) -->
<keep-alive :include="['Aa', 'Bb']">
<Aa v-if="index==0"></Aa>
<Bb v-if="index==1"></Bb>
</keep-alive>
 

#2.递归组件

​ 对于一些有规律的 dom 结构,我们可以通过递归方式来生成这个结构,那么在vue的模板中,我们能不能递归生成dom,答案是肯定的,在vue的组件中能够调用自己本身,不过它们只能通过 name 选项来做这件事。

首先为了使用递归组件需要准备一份数据,既然要用递归组件,那么对我们的数据格式肯定是需要满足递归的条件的,就像下边这样,这是一个树状的递归数据。

  data () {
return {
list: [
{
name: '苹果',
cList: [
{ name: '二级苹果1' },
{
name: '二级苹果2',
cList: [
{ name: '三级苹果1', cList: [{ name: '四级苹果1' }] }
]
}
]
},
{ name: '香蕉' },
{
name: '西瓜',
cList: [{ name: '二级西瓜1' }, { name: '二级西瓜2' }]
}
]
}
}
 

接下来,我们就用这个树状数据,做一个简单版的树状菜单。树状菜单,也是递归组件最常用的方法之一。

首先,我们先创建一个tree组件,这个组件作为使用递归组件的父组件,我们来看下具体写法

<template>
<div>
<my-trees :list="list"></my-trees>
</div>
</template>
<script>
import myTrees from './treeMenus'
export default {
name:"Tree",
components: {
myTrees
},
data () {
return {
list: [
{
name: '苹果',
cList: [
{ name: '二级苹果1' },
{
name: '二级苹果2',
cList: [
{ name: '三级苹果1', cList: [{ name: '四级苹果1' }] }
]
}
]
},
{ name: '香蕉' },
{
name: '西瓜',
cList: [{ name: '二级西瓜1' }, { name: '二级西瓜2' }]
}
]
}
},
methods: {} }
</script>
 

<my-trees />就是我们说的递归组件,当使用它时,只需要把上边我们定义好的数据通过props的方式传进去即可。

接下来,递归组件接收到了父组件传递的数据,就可以进行递归啦,我们来看下边treeMenus.vue中的实现:

<template>
<ul>
<li v-for="(item,index) in list " :key="index">
<p>{{item.name}}</p>
<tree-menus :list="item.cList"></tree-menus>
</li>
</ul>
</template>
<style>
ul{
padding-left: 20px!important;
}
</style>
<script>
export default{
name:'treeMenus',
props:{
list: Array
}
}
</script>
 

注意一开始所说,name属性的使用,你可以把它当作从import导入了一个组件并注册,我们在temlpate可以使用<tree-menus></tree-menus>使用子组件自身进行递归了。

#3.组件命名约定

当注册组件(或者 props)时,可以使用 kebab-case ,camelCase ,或 TitleCase 。

// 在组件定义中
components: {
// 使用 camelCase 形式注册
'kebab-cased-component': { /* ... */ },
'camelCasedComponent': { /* ... */ },
'TitleCasedComponent': { /* ... */ }
}
 

在 HTML 模版中,请使用 kebab-case 形式:

<!-- 在HTML模版中始终使用 kebab-case -->
<kebab-cased-component></kebab-cased-component>
<camel-cased-component></camel-cased-component>
<title-cased-component></title-cased-component>
 

当使用字符串模式时,可以不受 HTML 的 case-insensitive 限制。这意味实际上在模版中,你可以使用 camelCase 、 PascalCase 或者 kebab-case 来引用你的组件和 prop:

<!-- 在字符串模版中可以用任何你喜欢的方式-->
<my-component></my-component>
<myComponent></myComponent>
<MyComponent></MyComponent>


如果组件未经 slot 元素传递内容,你甚至可以在组件名后使用 / 使其自闭合:

<my-component/>
 

当然,这只在字符串模版中有效。因为自闭的自定义元素是无效的 HTML ,浏览器原生的解析器也无法识别它。

#授课思路

#案例和作业

使用递归组件方式完成如下图的多级菜单

vue第十单元(动态组件 keep-alive(钩子函数) 递归组件(name) 组件命名约定)的更多相关文章

  1. vue组件级路由钩子函数介绍,及实际应用

    正如其名,vue-router 提供的导航钩子主要用来拦截导航,让它完成跳转或取消. 有多种方式可以在路由导航发生时执行钩子:全局的.单个路由独享的.或者组件级的. 一.全局钩子 你可以使用 rout ...

  2. vue组件级路由钩子函数(beforeRouteEnter/beforeRouteUpdate/beforeRouteLeave)

    1.vue组件级路由钩子函数(beforeRouteEnter/beforeRouteUpdate/beforeRouteLeave):http://www.menvscode.com/detail/ ...

  3. vue第二十单元(vux的配置中模块modules的用法)

    第二十单元(vux的配置中模块modules的用法) #课程目标 1.什么是module? 2.怎么用module? 3.样板代码目录结构 #知识点 #1.modules 在Vue中State使用是单 ...

  4. vue组件路由守卫钩子函数(beforeRouteEnter、beforeRouteUpdate、beforeRouteLeave)

    用法:与mounted,created等同级并列. export default { data() { return { } }, methods: { go() { this.$router.pus ...

  5. vue 组件中的钩子函数 不能直接写this

    export default { data(){ return { num: 18 } }, beforeRouteEnter(to, from, next){ next(vm=>{ vm.nu ...

  6. vue学习目录 vue初识 this指向问题 vue组件传值 过滤器 钩子函数 路由 全家桶 脚手架 vuecli element-ui axios bus

    vue学习目录 vue学习目录 Vue学习一之vue初识 Vue学习二之vue结合项目简单使用.this指向问题 Vue学习三之vue组件 Vue学习四之过滤器.钩子函数.路由.全家桶等 Vue学习之 ...

  7. Vue 路由知识三(过渡动画及路由钩子函数)

    路由的过渡动画:让路由有过渡动画,需要在<router-view>标签的外部添加<transition>标签,标签还需要一个name属性. <transition nam ...

  8. vue学习(五)生命周期 的钩子函数

    生命周期的钩子函数 主要有以下几种 beforeCreate created beforeMount mounted beforeUpdate updated activated deactivate ...

  9. [前端] VUE基础 (5) (过滤器、生命周期、钩子函数)

    一.过滤器 过滤器分为局部过滤器和全局过滤器. 1.局部过滤器 <body> <div id="app"> </div> <script ...

随机推荐

  1. linux中的fork炸弹

    学习bash脚本看到一段代码(老鸟应该知道)挺有意思,一时看不懂.该命令不需要管理员即可运行,请不要在你的机器上使用以下脚本,否则你知道你在干什么 :() { :|: & };: 参考链接:h ...

  2. 如何在FL Studio中使用自动剪辑(下)

    在上集中我想大家介绍了FL Stduio Automation Clip的创建.播放列表操作及包络线类型介绍,在这篇文章中我将会给大家介绍如何在播放列表中使用Automation,剪辑通道的操作及使用 ...

  3. guitar pro系列教程(二十七):Guitar Pro教程之理解记谱法

    前面的章节我们讲解了很多关于Guitar Pro'的功能使用,今天小编还是采用图文结合的方式为大家讲解它的理解记谱法,对于很多新人来说,在我们看谱之前,我们肯定要先熟悉他的一些功能如何使用以及一些关于 ...

  4. go学习路线资料

    编辑器 JetBrains公司出品的,goland go初步学习路线 Go 指南 如何使用Go编程 实效Go编程 Go by Example 中文版 参考: Go 语言学习资料与社区索引 Go入门指南 ...

  5. Jmeter-记一次AES加密登录实例

    前言 公司有个网站系统,用户名是明文,密码是加密的,所以搞了好久才登录进去,因此记录下艰辛过程. Part 1   了解加密算法 找研发同事去了解这个是怎样一个加密过程,最后得到的结论是:后端会生成一 ...

  6. 网络拓扑实例之交换机基于全局地址池作为DHCP服务器(七)

    组网图形 DHCP服务器简介 通常用户希望网络中的每台终端能够动态获取IP地址.DNS服务器的IP地址.路由信息.网关信息等网络参数,不需要手动配置终端的IP地址等网络参数:另外,针对一些移动终端(手 ...

  7. 利用反射获取对象中的值等于x的字段

    Field[] field = behavior.getClass().getDeclaredFields(); for (int i = 0; i < field.length; i++) { ...

  8. k8s+docker_part2

    docker+k8s 目录 docker+k8s 1 简介 1.1 docker是什么 1.2 为什么要用docker 1.2.1 docker容器虚拟化的好处 1.2.2 docker在开发和运维中 ...

  9. C++/Java小白解Leetcode题,发现了知识盲区……

    一.初见LeetCode 大一时候学习C++,根据课程一直在PTA平台做题目,数据结构和算法的作业题目也是在PTA.后来发现牛客网学习资源也很丰富,孤陋寡闻,前几个月在知道LeetCode这个平台,跟 ...

  10. PADS生成贴片文件

    PADS生成贴片文件 VIEW-BOTTOM VIEW能够使Bottom层正常显示. 1. pastmask_top->Output Devices->Device Setup- 2. 进 ...