parent
ba3b3cdda9
commit
65beba98fe
@ -41,7 +41,7 @@ const _withId = /*#__PURE__*/_withScopeId(\\"test\\")
|
|||||||
export const render = /*#__PURE__*/_withId(function render(_ctx, _cache) {
|
export const render = /*#__PURE__*/_withId(function render(_ctx, _cache) {
|
||||||
const _component_Child = _resolveComponent(\\"Child\\")
|
const _component_Child = _resolveComponent(\\"Child\\")
|
||||||
|
|
||||||
return (_openBlock(), _createBlock(_component_Child, null, _createSlots({ _: 1 }, [
|
return (_openBlock(), _createBlock(_component_Child, null, _createSlots({ _: 2 }, [
|
||||||
(_ctx.ok)
|
(_ctx.ok)
|
||||||
? {
|
? {
|
||||||
name: \\"foo\\",
|
name: \\"foo\\",
|
||||||
|
@ -9,7 +9,7 @@ return function render(_ctx, _cache) {
|
|||||||
return (_openBlock(), _createBlock(_component_Comp, null, {
|
return (_openBlock(), _createBlock(_component_Comp, null, {
|
||||||
[_ctx.one]: _withCtx(({ foo }) => [_toDisplayString(foo), _toDisplayString(_ctx.bar)]),
|
[_ctx.one]: _withCtx(({ foo }) => [_toDisplayString(foo), _toDisplayString(_ctx.bar)]),
|
||||||
[_ctx.two]: _withCtx(({ bar }) => [_toDisplayString(_ctx.foo), _toDisplayString(bar)]),
|
[_ctx.two]: _withCtx(({ bar }) => [_toDisplayString(_ctx.foo), _toDisplayString(bar)]),
|
||||||
_: 1
|
_: 2
|
||||||
}, 1024 /* DYNAMIC_SLOTS */))
|
}, 1024 /* DYNAMIC_SLOTS */))
|
||||||
}"
|
}"
|
||||||
`;
|
`;
|
||||||
@ -35,7 +35,7 @@ exports[`compiler: transform component slots named slot with v-for w/ prefixIden
|
|||||||
return function render(_ctx, _cache) {
|
return function render(_ctx, _cache) {
|
||||||
const _component_Comp = _resolveComponent(\\"Comp\\")
|
const _component_Comp = _resolveComponent(\\"Comp\\")
|
||||||
|
|
||||||
return (_openBlock(), _createBlock(_component_Comp, null, _createSlots({ _: 1 }, [
|
return (_openBlock(), _createBlock(_component_Comp, null, _createSlots({ _: 2 }, [
|
||||||
_renderList(_ctx.list, (name) => {
|
_renderList(_ctx.list, (name) => {
|
||||||
return {
|
return {
|
||||||
name: name,
|
name: name,
|
||||||
@ -52,7 +52,7 @@ exports[`compiler: transform component slots named slot with v-if + prefixIdenti
|
|||||||
return function render(_ctx, _cache) {
|
return function render(_ctx, _cache) {
|
||||||
const _component_Comp = _resolveComponent(\\"Comp\\")
|
const _component_Comp = _resolveComponent(\\"Comp\\")
|
||||||
|
|
||||||
return (_openBlock(), _createBlock(_component_Comp, null, _createSlots({ _: 1 }, [
|
return (_openBlock(), _createBlock(_component_Comp, null, _createSlots({ _: 2 }, [
|
||||||
(_ctx.ok)
|
(_ctx.ok)
|
||||||
? {
|
? {
|
||||||
name: \\"one\\",
|
name: \\"one\\",
|
||||||
@ -72,7 +72,7 @@ return function render(_ctx, _cache) {
|
|||||||
|
|
||||||
const _component_Comp = _resolveComponent(\\"Comp\\")
|
const _component_Comp = _resolveComponent(\\"Comp\\")
|
||||||
|
|
||||||
return (_openBlock(), _createBlock(_component_Comp, null, _createSlots({ _: 1 }, [
|
return (_openBlock(), _createBlock(_component_Comp, null, _createSlots({ _: 2 }, [
|
||||||
ok
|
ok
|
||||||
? {
|
? {
|
||||||
name: \\"one\\",
|
name: \\"one\\",
|
||||||
@ -101,7 +101,7 @@ return function render(_ctx, _cache) {
|
|||||||
|
|
||||||
const _component_Comp = _resolveComponent(\\"Comp\\")
|
const _component_Comp = _resolveComponent(\\"Comp\\")
|
||||||
|
|
||||||
return (_openBlock(), _createBlock(_component_Comp, null, _createSlots({ _: 1 }, [
|
return (_openBlock(), _createBlock(_component_Comp, null, _createSlots({ _: 2 }, [
|
||||||
ok
|
ok
|
||||||
? {
|
? {
|
||||||
name: \\"one\\",
|
name: \\"one\\",
|
||||||
@ -145,7 +145,7 @@ return function render(_ctx, _cache) {
|
|||||||
default: _withCtx(({ foo }) => [
|
default: _withCtx(({ foo }) => [
|
||||||
_createVNode(_component_Inner, null, {
|
_createVNode(_component_Inner, null, {
|
||||||
default: _withCtx(({ bar }) => [_toDisplayString(foo), _toDisplayString(bar), _toDisplayString(_ctx.baz)]),
|
default: _withCtx(({ bar }) => [_toDisplayString(foo), _toDisplayString(bar), _toDisplayString(_ctx.baz)]),
|
||||||
_: 1
|
_: 2
|
||||||
}, 1024 /* DYNAMIC_SLOTS */),
|
}, 1024 /* DYNAMIC_SLOTS */),
|
||||||
\\" \\",
|
\\" \\",
|
||||||
_toDisplayString(foo),
|
_toDisplayString(foo),
|
||||||
@ -165,8 +165,8 @@ return function render(_ctx, _cache) {
|
|||||||
|
|
||||||
return (_openBlock(), _createBlock(_component_Comp, null, {
|
return (_openBlock(), _createBlock(_component_Comp, null, {
|
||||||
[_ctx.named]: _withCtx(({ foo }) => [_toDisplayString(foo), _toDisplayString(_ctx.bar)]),
|
[_ctx.named]: _withCtx(({ foo }) => [_toDisplayString(foo), _toDisplayString(_ctx.bar)]),
|
||||||
_: 1
|
_: 2
|
||||||
}))
|
}, 1024 /* DYNAMIC_SLOTS */))
|
||||||
}"
|
}"
|
||||||
`;
|
`;
|
||||||
|
|
||||||
|
@ -53,7 +53,7 @@ function parseWithSlots(template: string, options: CompilerOptions = {}) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function createSlotMatcher(obj: Record<string, any>) {
|
function createSlotMatcher(obj: Record<string, any>, isDynamic = false) {
|
||||||
return {
|
return {
|
||||||
type: NodeTypes.JS_OBJECT_EXPRESSION,
|
type: NodeTypes.JS_OBJECT_EXPRESSION,
|
||||||
properties: Object.keys(obj)
|
properties: Object.keys(obj)
|
||||||
@ -70,7 +70,7 @@ function createSlotMatcher(obj: Record<string, any>) {
|
|||||||
})
|
})
|
||||||
.concat({
|
.concat({
|
||||||
key: { content: `_` },
|
key: { content: `_` },
|
||||||
value: { content: `1`, isStatic: false }
|
value: { content: isDynamic ? `2` : `1`, isStatic: false }
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -230,29 +230,32 @@ describe('compiler: transform component slots', () => {
|
|||||||
{ prefixIdentifiers: true }
|
{ prefixIdentifiers: true }
|
||||||
)
|
)
|
||||||
expect(slots).toMatchObject(
|
expect(slots).toMatchObject(
|
||||||
createSlotMatcher({
|
createSlotMatcher(
|
||||||
'[_ctx.named]': {
|
{
|
||||||
type: NodeTypes.JS_FUNCTION_EXPRESSION,
|
'[_ctx.named]': {
|
||||||
params: {
|
type: NodeTypes.JS_FUNCTION_EXPRESSION,
|
||||||
type: NodeTypes.COMPOUND_EXPRESSION,
|
params: {
|
||||||
children: [`{ `, { content: `foo` }, ` }`]
|
type: NodeTypes.COMPOUND_EXPRESSION,
|
||||||
},
|
children: [`{ `, { content: `foo` }, ` }`]
|
||||||
returns: [
|
|
||||||
{
|
|
||||||
type: NodeTypes.INTERPOLATION,
|
|
||||||
content: {
|
|
||||||
content: `foo`
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
{
|
returns: [
|
||||||
type: NodeTypes.INTERPOLATION,
|
{
|
||||||
content: {
|
type: NodeTypes.INTERPOLATION,
|
||||||
content: `_ctx.bar`
|
content: {
|
||||||
|
content: `foo`
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
type: NodeTypes.INTERPOLATION,
|
||||||
|
content: {
|
||||||
|
content: `_ctx.bar`
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
]
|
}
|
||||||
}
|
},
|
||||||
})
|
true
|
||||||
|
)
|
||||||
)
|
)
|
||||||
expect(generate(root, { prefixIdentifiers: true }).code).toMatchSnapshot()
|
expect(generate(root, { prefixIdentifiers: true }).code).toMatchSnapshot()
|
||||||
})
|
})
|
||||||
@ -307,50 +310,53 @@ describe('compiler: transform component slots', () => {
|
|||||||
{ prefixIdentifiers: true }
|
{ prefixIdentifiers: true }
|
||||||
)
|
)
|
||||||
expect(slots).toMatchObject(
|
expect(slots).toMatchObject(
|
||||||
createSlotMatcher({
|
createSlotMatcher(
|
||||||
'[_ctx.one]': {
|
{
|
||||||
type: NodeTypes.JS_FUNCTION_EXPRESSION,
|
'[_ctx.one]': {
|
||||||
params: {
|
type: NodeTypes.JS_FUNCTION_EXPRESSION,
|
||||||
type: NodeTypes.COMPOUND_EXPRESSION,
|
params: {
|
||||||
children: [`{ `, { content: `foo` }, ` }`]
|
type: NodeTypes.COMPOUND_EXPRESSION,
|
||||||
},
|
children: [`{ `, { content: `foo` }, ` }`]
|
||||||
returns: [
|
|
||||||
{
|
|
||||||
type: NodeTypes.INTERPOLATION,
|
|
||||||
content: {
|
|
||||||
content: `foo`
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
{
|
returns: [
|
||||||
type: NodeTypes.INTERPOLATION,
|
{
|
||||||
content: {
|
type: NodeTypes.INTERPOLATION,
|
||||||
content: `_ctx.bar`
|
content: {
|
||||||
|
content: `foo`
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
type: NodeTypes.INTERPOLATION,
|
||||||
|
content: {
|
||||||
|
content: `_ctx.bar`
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
]
|
},
|
||||||
|
'[_ctx.two]': {
|
||||||
|
type: NodeTypes.JS_FUNCTION_EXPRESSION,
|
||||||
|
params: {
|
||||||
|
type: NodeTypes.COMPOUND_EXPRESSION,
|
||||||
|
children: [`{ `, { content: `bar` }, ` }`]
|
||||||
|
},
|
||||||
|
returns: [
|
||||||
|
{
|
||||||
|
type: NodeTypes.INTERPOLATION,
|
||||||
|
content: {
|
||||||
|
content: `_ctx.foo`
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
type: NodeTypes.INTERPOLATION,
|
||||||
|
content: {
|
||||||
|
content: `bar`
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
},
|
},
|
||||||
'[_ctx.two]': {
|
true
|
||||||
type: NodeTypes.JS_FUNCTION_EXPRESSION,
|
)
|
||||||
params: {
|
|
||||||
type: NodeTypes.COMPOUND_EXPRESSION,
|
|
||||||
children: [`{ `, { content: `bar` }, ` }`]
|
|
||||||
},
|
|
||||||
returns: [
|
|
||||||
{
|
|
||||||
type: NodeTypes.INTERPOLATION,
|
|
||||||
content: {
|
|
||||||
content: `_ctx.foo`
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
type: NodeTypes.INTERPOLATION,
|
|
||||||
content: {
|
|
||||||
content: `bar`
|
|
||||||
}
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
})
|
|
||||||
)
|
)
|
||||||
expect(generate(root, { prefixIdentifiers: true }).code).toMatchSnapshot()
|
expect(generate(root, { prefixIdentifiers: true }).code).toMatchSnapshot()
|
||||||
})
|
})
|
||||||
@ -382,35 +388,38 @@ describe('compiler: transform component slots', () => {
|
|||||||
type: NodeTypes.VNODE_CALL,
|
type: NodeTypes.VNODE_CALL,
|
||||||
tag: `_component_Inner`,
|
tag: `_component_Inner`,
|
||||||
props: undefined,
|
props: undefined,
|
||||||
children: createSlotMatcher({
|
children: createSlotMatcher(
|
||||||
default: {
|
{
|
||||||
type: NodeTypes.JS_FUNCTION_EXPRESSION,
|
default: {
|
||||||
params: {
|
type: NodeTypes.JS_FUNCTION_EXPRESSION,
|
||||||
type: NodeTypes.COMPOUND_EXPRESSION,
|
params: {
|
||||||
children: [`{ `, { content: `bar` }, ` }`]
|
type: NodeTypes.COMPOUND_EXPRESSION,
|
||||||
},
|
children: [`{ `, { content: `bar` }, ` }`]
|
||||||
returns: [
|
|
||||||
{
|
|
||||||
type: NodeTypes.INTERPOLATION,
|
|
||||||
content: {
|
|
||||||
content: `foo`
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
{
|
returns: [
|
||||||
type: NodeTypes.INTERPOLATION,
|
{
|
||||||
content: {
|
type: NodeTypes.INTERPOLATION,
|
||||||
content: `bar`
|
content: {
|
||||||
|
content: `foo`
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
type: NodeTypes.INTERPOLATION,
|
||||||
|
content: {
|
||||||
|
content: `bar`
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
type: NodeTypes.INTERPOLATION,
|
||||||
|
content: {
|
||||||
|
content: `_ctx.baz`
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
]
|
||||||
{
|
}
|
||||||
type: NodeTypes.INTERPOLATION,
|
},
|
||||||
content: {
|
true
|
||||||
content: `_ctx.baz`
|
),
|
||||||
}
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}),
|
|
||||||
// nested slot should be forced dynamic, since scope variables
|
// nested slot should be forced dynamic, since scope variables
|
||||||
// are not tracked as dependencies of the slot.
|
// are not tracked as dependencies of the slot.
|
||||||
patchFlag: genFlagText(PatchFlags.DYNAMIC_SLOTS)
|
patchFlag: genFlagText(PatchFlags.DYNAMIC_SLOTS)
|
||||||
@ -522,7 +531,7 @@ describe('compiler: transform component slots', () => {
|
|||||||
callee: CREATE_SLOTS,
|
callee: CREATE_SLOTS,
|
||||||
arguments: [
|
arguments: [
|
||||||
createObjectMatcher({
|
createObjectMatcher({
|
||||||
_: `[1]`
|
_: `[2]`
|
||||||
}),
|
}),
|
||||||
{
|
{
|
||||||
type: NodeTypes.JS_ARRAY_EXPRESSION,
|
type: NodeTypes.JS_ARRAY_EXPRESSION,
|
||||||
@ -564,7 +573,7 @@ describe('compiler: transform component slots', () => {
|
|||||||
callee: CREATE_SLOTS,
|
callee: CREATE_SLOTS,
|
||||||
arguments: [
|
arguments: [
|
||||||
createObjectMatcher({
|
createObjectMatcher({
|
||||||
_: `[1]`
|
_: `[2]`
|
||||||
}),
|
}),
|
||||||
{
|
{
|
||||||
type: NodeTypes.JS_ARRAY_EXPRESSION,
|
type: NodeTypes.JS_ARRAY_EXPRESSION,
|
||||||
@ -613,7 +622,7 @@ describe('compiler: transform component slots', () => {
|
|||||||
callee: CREATE_SLOTS,
|
callee: CREATE_SLOTS,
|
||||||
arguments: [
|
arguments: [
|
||||||
createObjectMatcher({
|
createObjectMatcher({
|
||||||
_: `[1]`
|
_: `[2]`
|
||||||
}),
|
}),
|
||||||
{
|
{
|
||||||
type: NodeTypes.JS_ARRAY_EXPRESSION,
|
type: NodeTypes.JS_ARRAY_EXPRESSION,
|
||||||
@ -672,7 +681,7 @@ describe('compiler: transform component slots', () => {
|
|||||||
callee: CREATE_SLOTS,
|
callee: CREATE_SLOTS,
|
||||||
arguments: [
|
arguments: [
|
||||||
createObjectMatcher({
|
createObjectMatcher({
|
||||||
_: `[1]`
|
_: `[2]`
|
||||||
}),
|
}),
|
||||||
{
|
{
|
||||||
type: NodeTypes.JS_ARRAY_EXPRESSION,
|
type: NodeTypes.JS_ARRAY_EXPRESSION,
|
||||||
|
@ -135,7 +135,7 @@ export function buildSlots(
|
|||||||
let hasDynamicSlots = context.scopes.vSlot > 0 || context.scopes.vFor > 0
|
let hasDynamicSlots = context.scopes.vSlot > 0 || context.scopes.vFor > 0
|
||||||
// with `prefixIdentifiers: true`, this can be further optimized to make
|
// with `prefixIdentifiers: true`, this can be further optimized to make
|
||||||
// it dynamic only when the slot actually uses the scope variables.
|
// it dynamic only when the slot actually uses the scope variables.
|
||||||
if (!__BROWSER__ && context.prefixIdentifiers) {
|
if (!__BROWSER__ && !context.ssr && context.prefixIdentifiers) {
|
||||||
hasDynamicSlots = hasScopeRef(node, context.identifiers)
|
hasDynamicSlots = hasScopeRef(node, context.identifiers)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -144,6 +144,9 @@ export function buildSlots(
|
|||||||
const onComponentSlot = findDir(node, 'slot', true)
|
const onComponentSlot = findDir(node, 'slot', true)
|
||||||
if (onComponentSlot) {
|
if (onComponentSlot) {
|
||||||
const { arg, exp } = onComponentSlot
|
const { arg, exp } = onComponentSlot
|
||||||
|
if (arg && !isStaticExp(arg)) {
|
||||||
|
hasDynamicSlots = true
|
||||||
|
}
|
||||||
slotsProperties.push(
|
slotsProperties.push(
|
||||||
createObjectProperty(
|
createObjectProperty(
|
||||||
arg || createSimpleExpression('default', true),
|
arg || createSimpleExpression('default', true),
|
||||||
@ -317,7 +320,12 @@ export function buildSlots(
|
|||||||
|
|
||||||
let slots = createObjectExpression(
|
let slots = createObjectExpression(
|
||||||
slotsProperties.concat(
|
slotsProperties.concat(
|
||||||
createObjectProperty(`_`, createSimpleExpression(`1`, false))
|
createObjectProperty(
|
||||||
|
`_`,
|
||||||
|
// 2 = compiled but dynamic = can skip normalization, but must run diff
|
||||||
|
// 1 = compiled and static = can skip normalization AND diff as optimized
|
||||||
|
createSimpleExpression(hasDynamicSlots ? `2` : `1`, false)
|
||||||
|
)
|
||||||
),
|
),
|
||||||
loc
|
loc
|
||||||
) as SlotsExpression
|
) as SlotsExpression
|
||||||
|
@ -140,7 +140,7 @@ describe('ssr: components', () => {
|
|||||||
return function ssrRender(_ctx, _push, _parent, _attrs) {
|
return function ssrRender(_ctx, _push, _parent, _attrs) {
|
||||||
const _component_foo = _resolveComponent(\\"foo\\")
|
const _component_foo = _resolveComponent(\\"foo\\")
|
||||||
|
|
||||||
_push(_ssrRenderComponent(_component_foo, _attrs, _createSlots({ _: 1 }, [
|
_push(_ssrRenderComponent(_component_foo, _attrs, _createSlots({ _: 2 }, [
|
||||||
(_ctx.ok)
|
(_ctx.ok)
|
||||||
? {
|
? {
|
||||||
name: \\"named\\",
|
name: \\"named\\",
|
||||||
@ -172,7 +172,7 @@ describe('ssr: components', () => {
|
|||||||
return function ssrRender(_ctx, _push, _parent, _attrs) {
|
return function ssrRender(_ctx, _push, _parent, _attrs) {
|
||||||
const _component_foo = _resolveComponent(\\"foo\\")
|
const _component_foo = _resolveComponent(\\"foo\\")
|
||||||
|
|
||||||
_push(_ssrRenderComponent(_component_foo, _attrs, _createSlots({ _: 1 }, [
|
_push(_ssrRenderComponent(_component_foo, _attrs, _createSlots({ _: 2 }, [
|
||||||
_renderList(_ctx.names, (key) => {
|
_renderList(_ctx.names, (key) => {
|
||||||
return {
|
return {
|
||||||
name: key,
|
name: key,
|
||||||
|
@ -11,7 +11,6 @@ import {
|
|||||||
isFunction,
|
isFunction,
|
||||||
EMPTY_OBJ,
|
EMPTY_OBJ,
|
||||||
ShapeFlags,
|
ShapeFlags,
|
||||||
PatchFlags,
|
|
||||||
extend,
|
extend,
|
||||||
def
|
def
|
||||||
} from '@vue/shared'
|
} from '@vue/shared'
|
||||||
@ -28,6 +27,11 @@ export type InternalSlots = {
|
|||||||
|
|
||||||
export type Slots = Readonly<InternalSlots>
|
export type Slots = Readonly<InternalSlots>
|
||||||
|
|
||||||
|
export const enum CompiledSlotTypes {
|
||||||
|
STATIC = 1,
|
||||||
|
DYNAMIC = 2
|
||||||
|
}
|
||||||
|
|
||||||
export type RawSlots = {
|
export type RawSlots = {
|
||||||
[name: string]: unknown
|
[name: string]: unknown
|
||||||
// manual render fn hint to skip forced children updates
|
// manual render fn hint to skip forced children updates
|
||||||
@ -40,7 +44,7 @@ export type RawSlots = {
|
|||||||
// object may be directly passed down to a child component in a manual
|
// object may be directly passed down to a child component in a manual
|
||||||
// render function, and the optimization hint need to be on the slot object
|
// render function, and the optimization hint need to be on the slot object
|
||||||
// itself to be preserved.
|
// itself to be preserved.
|
||||||
_?: 1
|
_?: CompiledSlotTypes
|
||||||
}
|
}
|
||||||
|
|
||||||
const isInternalKey = (key: string) => key[0] === '_' || key === '$stable'
|
const isInternalKey = (key: string) => key[0] === '_' || key === '$stable'
|
||||||
@ -105,10 +109,11 @@ export const initSlots = (
|
|||||||
children: VNodeNormalizedChildren
|
children: VNodeNormalizedChildren
|
||||||
) => {
|
) => {
|
||||||
if (instance.vnode.shapeFlag & ShapeFlags.SLOTS_CHILDREN) {
|
if (instance.vnode.shapeFlag & ShapeFlags.SLOTS_CHILDREN) {
|
||||||
if ((children as RawSlots)._ === 1) {
|
const type = (children as RawSlots)._
|
||||||
|
if (type) {
|
||||||
instance.slots = children as InternalSlots
|
instance.slots = children as InternalSlots
|
||||||
// make compiler marker non-enumerable
|
// make compiler marker non-enumerable
|
||||||
def(children as InternalSlots, '_', 1)
|
def(children as InternalSlots, '_', type)
|
||||||
} else {
|
} else {
|
||||||
normalizeObjectSlots(children as RawSlots, (instance.slots = {}))
|
normalizeObjectSlots(children as RawSlots, (instance.slots = {}))
|
||||||
}
|
}
|
||||||
@ -129,21 +134,20 @@ export const updateSlots = (
|
|||||||
let needDeletionCheck = true
|
let needDeletionCheck = true
|
||||||
let deletionComparisonTarget = EMPTY_OBJ
|
let deletionComparisonTarget = EMPTY_OBJ
|
||||||
if (vnode.shapeFlag & ShapeFlags.SLOTS_CHILDREN) {
|
if (vnode.shapeFlag & ShapeFlags.SLOTS_CHILDREN) {
|
||||||
if ((children as RawSlots)._ === 1) {
|
const type = (children as RawSlots)._
|
||||||
|
if (type) {
|
||||||
// compiled slots.
|
// compiled slots.
|
||||||
if (__DEV__ && isHmrUpdating) {
|
if (__DEV__ && isHmrUpdating) {
|
||||||
// Parent was HMR updated so slot content may have changed.
|
// Parent was HMR updated so slot content may have changed.
|
||||||
// force update slots and mark instance for hmr as well
|
// force update slots and mark instance for hmr as well
|
||||||
extend(slots, children as Slots)
|
extend(slots, children as Slots)
|
||||||
} else if (
|
} else if (type === CompiledSlotTypes.STATIC) {
|
||||||
// bail on dynamic slots (v-if, v-for, reference of scope variables)
|
|
||||||
!(vnode.patchFlag & PatchFlags.DYNAMIC_SLOTS)
|
|
||||||
) {
|
|
||||||
// compiled AND static.
|
// compiled AND static.
|
||||||
// no need to update, and skip stale slots removal.
|
// no need to update, and skip stale slots removal.
|
||||||
needDeletionCheck = false
|
needDeletionCheck = false
|
||||||
} else {
|
} else {
|
||||||
// compiled but dynamic - update slots, but skip normalization.
|
// compiled but dynamic (v-if/v-for on slots) - update slots, but skip
|
||||||
|
// normalization.
|
||||||
extend(slots, children as Slots)
|
extend(slots, children as Slots)
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import { Data } from '../component'
|
import { Data } from '../component'
|
||||||
import { Slots } from '../componentSlots'
|
import { Slots, RawSlots, CompiledSlotTypes } from '../componentSlots'
|
||||||
import {
|
import {
|
||||||
VNodeArrayChildren,
|
VNodeArrayChildren,
|
||||||
openBlock,
|
openBlock,
|
||||||
@ -39,7 +39,9 @@ export function renderSlot(
|
|||||||
Fragment,
|
Fragment,
|
||||||
{ key: props.key },
|
{ key: props.key },
|
||||||
slot ? slot(props) : fallback ? fallback() : [],
|
slot ? slot(props) : fallback ? fallback() : [],
|
||||||
slots._ ? PatchFlags.STABLE_FRAGMENT : PatchFlags.BAIL
|
(slots as RawSlots)._ === CompiledSlotTypes.STATIC
|
||||||
|
? PatchFlags.STABLE_FRAGMENT
|
||||||
|
: PatchFlags.BAIL
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user