Vue插槽总结及一点思考

Vue-slot

插槽的作用,就是给引用者一定的自我发挥空间,在引用组件内部,添点自定义的东西。
插槽内允许填充后备内容,为没有提供内容的引用作兜底显示。
v-slot只能用在组件标签或template标签上!

匿名插槽

匿名插槽有隐含的name: default。但我们往往不写,同时引用的子组件中,可以一次使用多个匿名插槽,但不建议这么做,毕竟渲染出的内容一模一样。

具名插槽

一个组件可以用多个具名插槽,具名插槽提供缩写#slotName,匿名插槽如想使用此写法即用#default

作用域插槽

可以让父组件拿到子组件独有的数据。

//子组件
<template>
  <div>
    <h3>作用域插槽</h3>
    <slot :colorList='colorList'>{{colorList.red}}(这里的red只是后备内容)</slot>
  </div>
</template>

//父组件引用
<Scope-slot>
  <template v-slot:default='{colorList}'>
     <p>{{colorList.blue}}</p>
  </template>
</Scope-slot>

v-slot后面需要指明slot的name,或者用独占默认插槽的缩写语法:v-slot=‘slotProps’,slotProps并不是固定名词,可以使用任意的名字替换。

同时父组件中的插槽prop支持结构写法,可用此方法来对传来的prop对象重命名("{ colorList: color }")、或设置默认值("{ colorList = { red : '红色' } }"

大家可以到我的沙盒来看看具体代码使用:沙盒链接

启发

在父子组件通信中,
props:父组件数据 -> 子组件,子组件只能读不能写,
slotProps:子组件数据 -> 父组件,父组件只能读不能写
.sync:父组件数据 -> 子组件,子组件“可读可写”(其实是通过$emit触发父组件改值而已)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值