插槽作用:让父组件可以向子组件指定位置插入html结构,也是一种组件间通信的方式,适用于 父组件 ===> 子组件 。
插槽分类:默认插槽、具名插槽、作用域插槽
理解插槽:数据在组件的自身或者是父组件在槽位传入,但根据数据生成的结构需要组件的使用者来决定(父级组件传入)。
通俗点来说:插槽就是子组件中的提供给父组件使用的一个占位符,用
如图,展示出了三个列表,其中列表中的数据与定义都在父组件,子组件只进行了渲染工作。可以先看下面三幅图。
看完上面三幅图相信大家对这个小案例有了一定的了解,接下来要做的就是使用插槽,对列表内的内容进行定制,实现在父组件内定义子组件时将样式传进去,从而实现相同的列表模板渲染出不同的效果,这得益于插槽可以将父组件中包含的html样式传送给子组件固定的槽位。
接下来咱们一起看看插槽如何使用吧。
这种实现方式会将html样式写在子组件内,实现之后可以发现子组件的内容已经写死,并没有办法在父组件实现更新与扩展。
核心代码(Lists组件):
{{title}}名单
- {{ i }}
匿名插槽就是没有名字的插槽,如何使用完全按照Vue的规则进行分配,如下图每一个匿名插槽均会将该组件标签包含的模板渲染一遍。
vue渲染匿名插槽的规则是:
将组件标签中包含的html完整的替换子组件内的插槽(子组件有多少个替换多少个)。
父组件的代码如下(App.vue):
//Lists标签包含的所有内容均会挂载到Lists组件内的solt标签上/* 之间的内容可以认为是父组件的一个槽位,页面渲染时会将槽位的内容放入子组件的插槽中*/- {{ i }}
Hello ![]()
子组件代码如下(Lists.vue):
{{title}}名单
具名插槽就是有名字的插槽,如何使用完全按照Vue的规则进行分配,渲染时根据名字进行精准渲染,没有内容传进来就使用默认内容。
vue渲染具名插槽的规则是:
将组件中包含的html有规则的替换子组件内相应的具名插槽(精准的替换)。
第一步就是在使用组件时定义模板要挂载到哪个插槽上
例:将图片挂载到插槽名为center的槽位
第二步就是在组件内定义插槽的位置。
例:这个槽位等待等待slot="center"的标签挂载。
我是一个插槽,我位于中间,当没有数据传过来的时候我会显示
父组件(App.vue)
子组件(Lists.vue)
{{title}}名单
我是一个插槽,我位于中间,当没有数据传过来的时候我会显示 我是一个插槽,我位于下面,当没有数据传过来的时候我会显示
作用域插槽,可以认为是子组件向父组件传送数据的第三种方式,可以将子组件的数据带到父组件内。
如图:目前页面上的数据定义均在子组件内,但是数据的使用却在父组件内。
作用域插槽:
插槽内的数据只在本插槽范围内起作用。
App.vue
- {{ g }}
- {{ g }}
{{ g }}
{{ msg }}
Lists.vue
{{title}}分类
我是默认的一些内容
到这里插槽的几种使用方式也就结束了,如果有更好的用法欢迎评论区留言!