ssrScopeId.spec.ts 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. import { compile } from '../src'
  2. const scopeId = 'data-v-xxxxxxx'
  3. describe('ssr: scopeId', () => {
  4. test('basic', () => {
  5. expect(
  6. compile(`<div><span>hello</span></div>`, {
  7. scopeId
  8. }).code
  9. ).toMatchInlineSnapshot(`
  10. "
  11. return function ssrRender(_ctx, _push, _parent) {
  12. _push(\`<div data-v-xxxxxxx><span data-v-xxxxxxx>hello</span></div>\`)
  13. }"
  14. `)
  15. })
  16. test('inside slots (only text)', () => {
  17. // should have no branching inside slot
  18. expect(
  19. compile(`<foo>foo</foo>`, {
  20. scopeId
  21. }).code
  22. ).toMatchInlineSnapshot(`
  23. "const { resolveComponent: _resolveComponent, createTextVNode: _createTextVNode } = require(\\"vue\\")
  24. const { ssrRenderComponent: _ssrRenderComponent } = require(\\"@vue/server-renderer\\")
  25. return function ssrRender(_ctx, _push, _parent) {
  26. const _component_foo = _resolveComponent(\\"foo\\")
  27. _push(_ssrRenderComponent(_component_foo, null, {
  28. default: (_, _push, _parent, _scopeId) => {
  29. if (_push) {
  30. _push(\`foo\`)
  31. } else {
  32. return [
  33. _createTextVNode(\\"foo\\")
  34. ]
  35. }
  36. },
  37. _: 1
  38. }, _parent))
  39. }"
  40. `)
  41. })
  42. test('inside slots (with elements)', () => {
  43. expect(
  44. compile(`<foo><span>hello</span></foo>`, {
  45. scopeId
  46. }).code
  47. ).toMatchInlineSnapshot(`
  48. "const { resolveComponent: _resolveComponent, createVNode: _createVNode } = require(\\"vue\\")
  49. const { ssrRenderComponent: _ssrRenderComponent } = require(\\"@vue/server-renderer\\")
  50. return function ssrRender(_ctx, _push, _parent) {
  51. const _component_foo = _resolveComponent(\\"foo\\")
  52. _push(_ssrRenderComponent(_component_foo, null, {
  53. default: (_, _push, _parent, _scopeId) => {
  54. if (_push) {
  55. _push(\`<span data-v-xxxxxxx\${_scopeId}>hello</span>\`)
  56. } else {
  57. return [
  58. _createVNode(\\"span\\", null, \\"hello\\")
  59. ]
  60. }
  61. },
  62. _: 1
  63. }, _parent))
  64. }"
  65. `)
  66. })
  67. test('nested slots', () => {
  68. expect(
  69. compile(`<foo><span>hello</span><bar><span/></bar></foo>`, {
  70. scopeId
  71. }).code
  72. ).toMatchInlineSnapshot(`
  73. "const { resolveComponent: _resolveComponent, createVNode: _createVNode } = require(\\"vue\\")
  74. const { ssrRenderComponent: _ssrRenderComponent } = require(\\"@vue/server-renderer\\")
  75. return function ssrRender(_ctx, _push, _parent) {
  76. const _component_foo = _resolveComponent(\\"foo\\")
  77. const _component_bar = _resolveComponent(\\"bar\\")
  78. _push(_ssrRenderComponent(_component_foo, null, {
  79. default: (_, _push, _parent, _scopeId) => {
  80. if (_push) {
  81. _push(\`<span data-v-xxxxxxx\${_scopeId}>hello</span>\`)
  82. _push(_ssrRenderComponent(_component_bar, null, {
  83. default: (_, _push, _parent, _scopeId) => {
  84. if (_push) {
  85. _push(\`<span data-v-xxxxxxx\${_scopeId}></span>\`)
  86. } else {
  87. return [
  88. _createVNode(\\"span\\")
  89. ]
  90. }
  91. },
  92. _: 1
  93. }, _parent))
  94. } else {
  95. return [
  96. _createVNode(\\"span\\", null, \\"hello\\"),
  97. _createVNode(_component_bar, null, {
  98. default: () => [
  99. _createVNode(\\"span\\")
  100. ],
  101. _: 1
  102. })
  103. ]
  104. }
  105. },
  106. _: 1
  107. }, _parent))
  108. }"
  109. `)
  110. })
  111. })