Pulled ALL skills from 15 source repositories: - anthropics/skills: 16 (docs, design, MCP, testing) - obra/superpowers: 14 (TDD, debugging, agents, planning) - coreyhaines31/marketingskills: 25 (marketing, CRO, SEO, growth) - better-auth/skills: 5 (auth patterns) - vercel-labs/agent-skills: 5 (React, design, Vercel) - antfu/skills: 16 (Vue, Vite, Vitest, pnpm, Turborepo) - Plus 13 individual skills from various repos Mosaic Stack is not limited to coding — the Orchestrator and subagents serve coding, business, design, marketing, writing, logistics, analysis, and more. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2.7 KiB
2.7 KiB
title, impact, impactDescription, type, tags
| title | impact | impactDescription | type | tags | |||||
|---|---|---|---|---|---|---|---|---|---|
| Slot Name is Reserved and Not Included in Slot Props | LOW | Expecting 'name' in scoped slot props when it's reserved causes confusion | gotcha |
|
Slot Name is Reserved and Not Included in Slot Props
Impact: LOW - When using scoped slots, the name attribute on the <slot> element is reserved for identifying the slot. It is not passed as part of the slot props to the parent component.
Task Checklist
- Don't expect
namein slot props - it's reserved - Use a different prop name if you need to pass a name value
- Remember only explicitly bound attributes become slot props
Incorrect Expectation:
<!-- ChildComponent.vue -->
<template>
<div>
<slot name="header" title="Welcome"></slot>
</div>
</template>
<!-- ParentComponent.vue -->
<ChildComponent>
<template #header="props">
<!-- props = { title: "Welcome" } -->
<!-- 'name' is NOT included! -->
{{ props.name }} <!-- undefined -->
{{ props.title }} <!-- "Welcome" -->
</template>
</ChildComponent>
If You Need to Pass a "Name" Value:
<!-- ChildComponent.vue -->
<template>
<div>
<!-- Use a different prop name like 'slotName' or 'label' -->
<slot name="header" :label="slotLabel" :title="title"></slot>
</div>
</template>
<script setup>
const slotLabel = 'header'
const title = 'Welcome'
</script>
<!-- ParentComponent.vue -->
<ChildComponent>
<template #header="{ label, title }">
<h2>{{ title }}</h2>
<span>Section: {{ label }}</span>
</template>
</ChildComponent>
What Gets Passed as Slot Props
Attribute on <slot> |
Passed to Parent? |
|---|---|
name |
No (reserved for slot identification) |
:text="message" |
Yes, as text |
:count="5" |
Yes, as count |
v-bind="object" |
Yes, spreads object properties |
class="..." |
No (not bound with :) |
Multiple Named Slots Example
<!-- TabPanel.vue -->
<template>
<div class="tabs">
<slot name="tab1" :active="activeTab === 1" :label="'First Tab'"></slot>
<slot name="tab2" :active="activeTab === 2" :label="'Second Tab'"></slot>
</div>
</template>
<script setup>
import { ref } from 'vue'
const activeTab = ref(1)
</script>
<!-- Usage -->
<TabPanel>
<template #tab1="{ active, label }">
<!-- 'name' not available, but 'label' is -->
<button :class="{ active }">{{ label }}</button>
</template>
<template #tab2="{ active, label }">
<button :class="{ active }">{{ label }}</button>
</template>
</TabPanel>