插槽 Slots

简介: 插槽 Slots

插槽内容与出口

在之前的章节中,我们已经了解到组件能够接收任意类型的 JavaScript 值作为 props,但组件要如何接收模板内容呢?在某些场景中,我们可能想要为子组件传递一些模板片段,让子组件在它们的组件中渲染这些片段。

举例来说,这里有一个 <FancyButton> 组件,可以像这样使用:

<FancyButton>
  Click me! <!-- 插槽内容 -->
</FancyButton>

<FancyButton> 的模板是这样的:

<button class="fancy-btn">
  <slot></slot> <!-- 插槽出口 -->
</button>

<slot> 元素是一个插槽出口 (slot outlet),标示了父元素提供的插槽内容 (slot content) 将在哪里被渲染。

<button class="fancy-btn">Click me!</button>

 

通过使用插槽,<FancyButton> 仅负责渲染外层的 <button> (以及相应的样式),而其内部的内容由父组件提供。

理解插槽的另一种方式是和下面的 JavaScript 函数作类比,其概念是类似的:

// 父元素传入插槽内容
FancyButton('Click me!')
// FancyButton 在自己的模板中渲染插槽内容
function FancyButton(slotContent) {
  return `<button class="fancy-btn">
      ${slotContent}
    </button>`
}
<FancyButton>
  <span style="color:red">Click me!</span>
  <AwesomeIcon name="plus" />
</FancyButton>

通过使用插槽,<FancyButton> 组件更加灵活和具有可复用性。现在组件可以用在不同的地方渲染各异的内容,但同时还保证都具有相同的样式。

相关文章
|
6天前
|
JavaScript 前端开发 开发者
vue的slot插槽详解
vue的slot插槽详解
30 0
|
6天前
|
JavaScript API
vue插槽slot、slot-scope、v-slot的区别以及嵌套插槽的使用
可以将 slot 理解成一个占位的东西,我们提前在模板中放置一个占位的标记,当其他地方要使用模板时就可以通过标记再传进来具体的内容,这样就可以实现更强的复用能力。
54 2
|
6天前
|
JavaScript
#是啥,v-slot插槽的区别
#是啥,v-slot插槽的区别
|
7月前
|
API
66Vue - Slots 分发内容(具名Slots)
66Vue - Slots 分发内容(具名Slots)
25 0
|
6天前
|
JavaScript
Vue插槽(slot)的使用
Vue插槽(slot)的使用
14 1
|
6天前
|
JavaScript 前端开发
Vue之插槽Slot理解
Vue之插槽Slot理解
23 0
|
6天前
|
JavaScript
对于Vue Slot插槽的讲解
对于Vue Slot插槽的讲解
|
7月前
|
JavaScript
65Vue - Slots 分发内容(单个 Slot)
65Vue - Slots 分发内容(单个 Slot)
20 0
|
8月前
|
JavaScript
说说你对slot的理解?slot使用场景有哪些?
说说你对slot的理解?slot使用场景有哪些?
94 1
|
9月前
|
JavaScript
vue 插槽的作用,用插槽slot-scope获取表格中的数据
vue 插槽的作用,用插槽slot-scope获取表格中的数据
146 0