合规国际互联网加速 OSASE为企业客户提供高速稳定SD-WAN国际加速解决方案。 广告
>[success] # 插槽 1. 组件的插槽也是为了让我们封装的组件更加具有扩展性。 2. 使用 `<slot>` 标签预留插槽 3. 多个插槽的时候使用`name ` 属性进行占位,并且在对应js 文件配置`multipleSlots:true` ~~~ Component({ options: { multipleSlots: true } }) ~~~ >[danger] ##### 单个标签插槽 1. 小程序的插槽不支持默认值,因此想默认值需要使用`css` 帮助来实现 * 定义一个组件 ~~~html <view> <view>单个插槽</view> <view class="content"> <!-- 小程序中插槽是不支持默认值的 --> <slot></slot> </view> <!-- 利用css 做默认值 --> <view class="default">哈哈哈哈</view> </view> ~~~ * `wxss` 文件,利用`css `如果`content `为空那么他的兄弟 `default`元素 则显示 ~~~css .default { display: none; } .content:empty + .default { display: block; } ~~~ * 使用组件 ~~~ { "usingComponents": { "slot-demo":"/componets/single-slot/single-slot" } } ~~~ ~~~html <slot-demo> 添加默认值 </slot-demo> ~~~ >[danger] ##### 多个插槽 ![](https://img.kancloud.cn/cf/50/cf505daa37cd58e83abc58a50b40c83c_469x55.png) ~~~ html <view class="mul-slot"> <view class="letf"> <slot name="left"></slot> </view> <view class="center"> <slot name="center"></slot> </view> <view class="right"> <slot name="right"></slot> </view> </view> ~~~ ~~~ .mul-slot { display: flex; text-align: center; } .right,.left{ width: 160rpx; } .center { flex: 1; } ~~~ ~~~ Component({ options: { multipleSlots: true } }) ~~~ * 如果已经注册使用 ~~~html <mul-slot> <button slot="left" size="mini">left</button> <view slot="center">哈哈哈</view> <button slot="right" size="mini">right</button> </mul-slot> ~~~