插槽也就是slot,是组件的一块HTML模板,这块模板显示不显示以及怎样显示由父组件来决定。
由于插槽是一块模板,所以,对于任何一个组件,从模板种类的角度来分,其实都可以分为非插槽模板和插槽模板两大类。
- 非插槽模板指的是html模板,指的是‘div、span、ul、table’这些,非插槽模板的显示与隐藏以及怎样显示由插件自身控制;
- 插槽模板是slot,它是一个空壳子,因为它显示与隐藏以及最后用什么样的html模板显示由父组件控制。但是插槽显示的位置确由子组件自身决定,slot写在组件template的哪块,父组件传过来的模板将来就显示在哪块。
1. 单个插槽 | 默认插槽 | 匿名插槽
不用设置name属性。单个插槽可以放置在组件的任意位置,一个组件中只能有一个该类插槽。相对应的,具名插槽就可以有很多个,只要名字(name属性)不同就可以了。
父组件:
我是父组件
第一行
第二行
第三行
子组件:
我是子组件
效果图:

2. 具名插槽
带有名字的插槽,有一个name属性,具名的插槽可以在组件中出现多次,而之前的匿名插槽只能出现一次。
父组件:
我是父组件
first-第一行
first-第二行
first-第三行
second-第一行
second-第二行
second-第三行
第一行
第二行
第三行
子组件:
我是子组件
效果图:

父组件通过html模板上的slot属性关联具名插槽。没有slot属性的html模板默认关联匿名插槽。
3. 作用域插槽 | 带数据插槽
作用域插槽实际上是带有数据的插槽,可以获取到父组件传递的参数,将这些参数使用到子组件插槽里。
作用域插槽和单个插槽和具名插槽的区别,因为单个插槽和具名插槽不绑定数据,所以父组件是提供的模板要既包括样式又包括内容的;而作用域插槽,父组件只需要提供一套样式(在确实用作用域插槽绑定的数据的前提下)。
父组件:
我是父组件
first-第一行
first-第二行
first-第三行
second-第一行
second-第二行
second-第三行
第一行
第二行
第三行
- {
{item}}
子组件:
我是子组件
效果图:

以上效果可以看出,具名插槽可以多个,匿名插槽只能一个;
作用域插槽通常在el-table中比较常用到:scope.row 当前行的数据对象
暂无数据
{
{columnIndex(scope.$index)}}
{
{ scope.row[scope.column.property] }}
发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/212468.html原文链接:https://javaforall.net
