mirror of https://github.com/vuejs/core.git
207 lines
5.0 KiB
TypeScript
207 lines
5.0 KiB
TypeScript
import { createApp } from 'vue'
|
|
import { renderToString } from '../src/renderToString'
|
|
|
|
const components = {
|
|
one: {
|
|
template: `<div><slot/></div>`,
|
|
},
|
|
}
|
|
|
|
describe('ssr: slot', () => {
|
|
test('text slot', async () => {
|
|
expect(
|
|
await renderToString(
|
|
createApp({
|
|
components,
|
|
template: `<one>hello</one>`,
|
|
}),
|
|
),
|
|
).toBe(`<div><!--[-->hello<!--]--></div>`)
|
|
})
|
|
|
|
test('element slot', async () => {
|
|
expect(
|
|
await renderToString(
|
|
createApp({
|
|
components,
|
|
template: `<one><div>hi</div></one>`,
|
|
}),
|
|
),
|
|
).toBe(`<div><!--[--><div>hi</div><!--]--></div>`)
|
|
})
|
|
|
|
test('empty slot', async () => {
|
|
expect(
|
|
await renderToString(
|
|
createApp({
|
|
components: {
|
|
one: {
|
|
template: `<div><slot/></div>`,
|
|
},
|
|
},
|
|
template: `<one><template v-if="false"/></one>`,
|
|
}),
|
|
),
|
|
).toBe(`<div><!--[--><!--]--></div>`)
|
|
})
|
|
|
|
test('empty slot (manual comments)', async () => {
|
|
expect(
|
|
await renderToString(
|
|
createApp({
|
|
components: {
|
|
one: {
|
|
template: `<div><slot/></div>`,
|
|
},
|
|
},
|
|
template: `<one><!--hello--></one>`,
|
|
}),
|
|
),
|
|
).toBe(`<div><!--[--><!--]--></div>`)
|
|
})
|
|
|
|
test('empty slot (multi-line comments)', async () => {
|
|
expect(
|
|
await renderToString(
|
|
createApp({
|
|
components: {
|
|
one: {
|
|
template: `<div><slot/></div>`,
|
|
},
|
|
},
|
|
template: `<one><!--he\nllo--></one>`,
|
|
}),
|
|
),
|
|
).toBe(`<div><!--[--><!--]--></div>`)
|
|
})
|
|
|
|
test('multiple elements', async () => {
|
|
expect(
|
|
await renderToString(
|
|
createApp({
|
|
components,
|
|
template: `<one><div>one</div><div>two</div></one>`,
|
|
}),
|
|
),
|
|
).toBe(`<div><!--[--><div>one</div><div>two</div><!--]--></div>`)
|
|
})
|
|
|
|
test('fragment slot (template v-if)', async () => {
|
|
expect(
|
|
await renderToString(
|
|
createApp({
|
|
components,
|
|
template: `<one><template v-if="true">hello</template></one>`,
|
|
}),
|
|
),
|
|
).toBe(`<div><!--[--><!--[-->hello<!--]--><!--]--></div>`)
|
|
})
|
|
|
|
test('fragment slot (template v-if + multiple elements)', async () => {
|
|
expect(
|
|
await renderToString(
|
|
createApp({
|
|
components,
|
|
template: `<one><template v-if="true"><div>one</div><div>two</div></template></one>`,
|
|
}),
|
|
),
|
|
).toBe(
|
|
`<div><!--[--><!--[--><div>one</div><div>two</div><!--]--><!--]--></div>`,
|
|
)
|
|
})
|
|
|
|
test('transition slot', async () => {
|
|
expect(
|
|
await renderToString(
|
|
createApp({
|
|
components: {
|
|
one: {
|
|
template: `<transition><slot/></transition>`,
|
|
},
|
|
},
|
|
template: `<one><div v-if="false">foo</div></one>`,
|
|
}),
|
|
),
|
|
).toBe(`<!---->`)
|
|
|
|
expect(
|
|
await renderToString(
|
|
createApp({
|
|
components: {
|
|
one: {
|
|
template: `<transition><slot/></transition>`,
|
|
},
|
|
},
|
|
template: `<one><div v-if="true">foo</div></one>`,
|
|
}),
|
|
),
|
|
).toBe(`<div>foo</div>`)
|
|
})
|
|
|
|
// #9933
|
|
test('transition-group slot', async () => {
|
|
expect(
|
|
await renderToString(
|
|
createApp({
|
|
components: {
|
|
one: {
|
|
template: `<TransitionGroup tag="div"><slot/></TransitionGroup>`,
|
|
},
|
|
},
|
|
template: `<one><p v-for="i in 2">{{i}}</p></one>`,
|
|
}),
|
|
),
|
|
).toBe(`<div><p>1</p><p>2</p></div>`)
|
|
})
|
|
|
|
// #11326
|
|
test('dynamic component slot', async () => {
|
|
expect(
|
|
await renderToString(
|
|
createApp({
|
|
components: {
|
|
ButtonComp: {
|
|
template: `<component is="button"><slot/></component>`,
|
|
},
|
|
Wrap: {
|
|
template: `<div><slot/></div>`,
|
|
},
|
|
},
|
|
template: `<ButtonComp><Wrap><div v-if="false">hello</div></Wrap></ButtonComp>`,
|
|
}),
|
|
),
|
|
).toBe(`<button><!--[--><div><!--[--><!--]--></div><!--]--></button>`)
|
|
|
|
expect(
|
|
await renderToString(
|
|
createApp({
|
|
components: {
|
|
ButtonComp: {
|
|
template: `<component is="button"><slot/></component>`,
|
|
},
|
|
Wrap: {
|
|
template: `<div><slot/></div>`,
|
|
},
|
|
},
|
|
template: `<ButtonComp><Wrap><div v-if="true">hello</div></Wrap></ButtonComp>`,
|
|
}),
|
|
),
|
|
).toBe(
|
|
`<button><!--[--><div><!--[--><div>hello</div><!--]--></div><!--]--></button>`,
|
|
)
|
|
|
|
expect(
|
|
await renderToString(
|
|
createApp({
|
|
components: {
|
|
ButtonComp: {
|
|
template: `<component is="button"><slot/></component>`,
|
|
},
|
|
},
|
|
template: `<ButtonComp><template v-if="false">hello</template></ButtonComp>`,
|
|
}),
|
|
),
|
|
).toBe(`<button><!--[--><!--]--></button>`)
|
|
})
|
|
})
|