diff --git a/packages/compiler-core/src/transforms/hoistStatic.ts b/packages/compiler-core/src/transforms/hoistStatic.ts index 004a1e5a..e528fdae 100644 --- a/packages/compiler-core/src/transforms/hoistStatic.ts +++ b/packages/compiler-core/src/transforms/hoistStatic.ts @@ -111,7 +111,14 @@ function walk( // walk further if (child.type === NodeTypes.ELEMENT) { + const isComponent = child.tagType === ElementTypes.COMPONENT + if (isComponent) { + context.scopes.vSlot++ + } walk(child, context) + if (isComponent) { + context.scopes.vSlot-- + } } else if (child.type === NodeTypes.FOR) { // Do not hoist v-for single child because it has to be a block walk(child, context, child.children.length === 1) diff --git a/packages/compiler-dom/src/transforms/stringifyStatic.ts b/packages/compiler-dom/src/transforms/stringifyStatic.ts index 94a4e053..7e4c66ad 100644 --- a/packages/compiler-dom/src/transforms/stringifyStatic.ts +++ b/packages/compiler-dom/src/transforms/stringifyStatic.ts @@ -60,11 +60,8 @@ type StringifiableNode = PlainElementNode | TextCallNode * This optimization is only performed in Node.js. */ export const stringifyStatic: HoistTransform = (children, context, parent) => { - if ( - parent.type === NodeTypes.ELEMENT && - (parent.tagType === ElementTypes.COMPONENT || - parent.tagType === ElementTypes.TEMPLATE) - ) { + // bail stringification for slot content + if (context.scopes.vSlot > 0) { return }