Vue 作用域插槽

目的:插槽内容能够访问子组件中才有的数据是很有用的

父组件

<template>
  <div>
    <h1>作用域插槽: 绑定在<slot>;元素上的attribute被称为插槽Prop</h1>
    <slot-context>
      <h3>默认插槽: defalut slot content</h3>
      <!-- ❌❌❌ 插槽写法 #title ❌❌❌ -->
      <template #default="props">
        <h3 style="color:#FFAF40">父组件:default 默认作用域插槽</h3>
        <h3 style="color:#409EFF">v-slot:title="props" {{props.slotProps}}</h3>
      </template>
      <!-- ❌❌❌ 插槽写法 #title ❌❌❌ -->
      <template #title="props">
        <h3 style="color:#FFAF40">父组件:title 具名的作用域插槽====使用#</h3>
        <h3 style="color:#409EFF">v-slot:title="props" {{props.slotProps}}</h3>
      </template>
      <!-- 🌐🌐🌐 插槽写法 v-slot: 🌐🌐🌐 -->
      <template v-slot:item="props">
        <h3 style="color:#FFAF40">父组件:item 具名的作用域插槽====使用v-slot:</h3>
        <h3 style="color:#FFAF40">v-slot:item="props" => {{props.slotProps}}</h3>
      </template>
      <!-- ⏹⏹⏹ 插槽写法 slot="slotName" slot-scope="slotProps" ⏹⏹⏹ -->
      <template slot="other" slot-scope="props">
        <h3 style="color:#FFAF40">父组件:other 具名的作用域插槽</h3>
        <h3 style="color:#FFAF40">v-slot:item="props" => {{props.slotProps}}</h3>
      </template>
    </slot-context>
  </div>
</template>

<script>
import slotContext from './slot-context.vue'
export default {
  components: { slotContext }
}
</script>

子组件

<template>
  <div class="new-slot">
    <slot :slotProps="defaultObj" />
    <slot name="title" :slotProps="titleObj" />
    <slot name="item" :slotProps="itemObj" />
    <slot name="other" :slotProps="otherObj" />
  </div>
</template>
<script>
export default {
  data() {
    return {
      defaultObj: { team: 'Liverpool', member: 'Steve Gerrard' },
      itemObj: { height: 110, width: 220 },
      titleObj: { name: 'leslie', love: 'javascript' },
      otherObj: { company: 'vh', id: 'VH001667' },
    }
  }
}
</script>
<style lang="scss">
.new-slot {
  border: 1px solid gray;
  padding: 20px;
}
</style>

posted @ 2020-07-22 11:02  荣光无限  阅读(256)  评论(0编辑  收藏  举报