vue3-yuanma/packages/compiler-ssr/__tests__/ssrVShow.spec.ts

86 lines
2.6 KiB
TypeScript
Raw Normal View History

2020-02-05 02:03:16 +00:00
import { compile } from '../src'
describe('ssr: v-show', () => {
test('basic', () => {
expect(compile(`<div v-show="foo"/>`).code).toMatchInlineSnapshot(`
"const { ssrRenderStyle: _ssrRenderStyle } = require(\\"@vue/server-renderer\\")
2020-02-05 02:03:16 +00:00
return function ssrRender(_ctx, _push, _parent) {
2020-02-06 17:09:09 +00:00
_push(\`<div\${_ssrRenderStyle((_ctx.foo) ? null : { display: \\"none\\" })}></div>\`)
2020-02-05 02:03:16 +00:00
}"
`)
})
test('with static style', () => {
expect(compile(`<div style="color:red" v-show="foo"/>`).code)
.toMatchInlineSnapshot(`
"const { ssrRenderStyle: _ssrRenderStyle } = require(\\"@vue/server-renderer\\")
2020-02-05 02:03:16 +00:00
const _hoisted_1 = {\\"color\\":\\"red\\"}
return function ssrRender(_ctx, _push, _parent) {
2020-02-06 17:09:09 +00:00
_push(\`<div\${_ssrRenderStyle([
2020-02-05 02:03:16 +00:00
_hoisted_1,
(_ctx.foo) ? null : { display: \\"none\\" }
])}></div>\`)
}"
`)
})
test('with dynamic style', () => {
expect(compile(`<div :style="{ color: 'red' }" v-show="foo"/>`).code)
.toMatchInlineSnapshot(`
"const { ssrRenderStyle: _ssrRenderStyle } = require(\\"@vue/server-renderer\\")
2020-02-05 02:03:16 +00:00
return function ssrRender(_ctx, _push, _parent) {
2020-02-06 17:09:09 +00:00
_push(\`<div\${_ssrRenderStyle([
2020-02-05 02:03:16 +00:00
{ color: 'red' },
(_ctx.foo) ? null : { display: \\"none\\" }
])}></div>\`)
}"
`)
})
test('with static + dynamic style', () => {
expect(
compile(`<div style="color:red" :style="{ fontSize: 14 }" v-show="foo"/>`)
.code
).toMatchInlineSnapshot(`
"const { ssrRenderStyle: _ssrRenderStyle } = require(\\"@vue/server-renderer\\")
2020-02-05 02:03:16 +00:00
const _hoisted_1 = {\\"color\\":\\"red\\"}
return function ssrRender(_ctx, _push, _parent) {
2020-02-06 17:09:09 +00:00
_push(\`<div\${_ssrRenderStyle([
2020-02-05 02:03:16 +00:00
_hoisted_1,
{ fontSize: 14 },
(_ctx.foo) ? null : { display: \\"none\\" }
])}></div>\`)
}"
`)
})
test('with v-bind', () => {
expect(
compile(
`<div v-bind="baz" style="color:red" :style="{ fontSize: 14 }" v-show="foo"/>`
).code
).toMatchInlineSnapshot(`
"const { mergeProps: _mergeProps } = require(\\"vue\\")
const { ssrRenderAttrs: _ssrRenderAttrs } = require(\\"@vue/server-renderer\\")
2020-02-05 02:03:16 +00:00
const _hoisted_1 = {\\"color\\":\\"red\\"}
return function ssrRender(_ctx, _push, _parent) {
_push(\`<div\${_ssrRenderAttrs(_mergeProps(_ctx.baz, {
2020-02-05 02:03:16 +00:00
style: [
_hoisted_1,
{ fontSize: 14 },
(_ctx.foo) ? null : { display: \\"none\\" }
]
}))}></div>\`)
}"
`)
})
})