Vue动态组件,插槽及自定义指令

1. 动态组件

动态组件指的是动态切换组件的显示与隐藏。
vue 提供了一个内置的 组件,专门用来实现动态组件的渲染。示例代码如下:
Vue动态组件,插槽及自定义指令_第1张图片
使用 keep-alive 保持状态:默认情况下,切换动态组件时无法保持组件的状态。此时可以使用 vue 内置的 组件保持动态组件的状态。
include 属性用来指定:只有名称匹配的组件会被缓存。多个组件名之间使用英文的逗号分隔:

 	<keep-alive include="MyRight">
        <component :is="comName"></component>
     </keep-alive>

keep-alive 对应的生命周期函数
当组件被缓存时,会自动触发组件的 deactivated 生命周期函数。
当组件被激活时,会自动触发组件的 activated 生命周期函数。

2. 插槽

插槽(Slot)是 vue 为组件的封装者提供的能力。允许开发者在封装组件时,把不确定的、希望由用户指定的部分定义为插槽。

可以把插槽认为是组件封装期间,为用户预留的内容的占位符

2.1插槽的基础用法:
在封装组件时,可以通过 元素定义插槽,从而为用户预留内容占位符。示例代码如下:
Vue动态组件,插槽及自定义指令_第2张图片
如果在封装组件时没有预留任何 插槽,则用户提供的任何自定义内容都会被丢弃。
封装组件时,可以为预留的 插槽提供后备内容(默认内容)。如果组件的使用者没有为插槽提供任何内容,则后备内容会生效。
Vue动态组件,插槽及自定义指令_第3张图片
2.2 具名插槽
如果在封装组件时需要预留多个插槽节点,则需要为每个 插槽指定具体的 name 名称。这种带有具体名称的插槽叫做“具名插槽”。示例代码如下:
Vue动态组件,插槽及自定义指令_第4张图片
注意:没有指定 name 名称的插槽,会有隐含的名称叫做 “default”。

在向具名插槽提供内容的时候,我们可以在一个 元素上使用 v-slot 指令,并以 v-slot 的参数的形式提供其名称。示例代码如下:
Vue动态组件,插槽及自定义指令_第5张图片

3. 自定义指令

你可能感兴趣的:(vue,vue.js,javascript,前端)