Skip to content

Commit 1f75d4e

Browse files
authoredNov 15, 2024··
fix(ssr): ensure v-text updates correctly with custom directives in SSR output (#12311)
close #12309
1 parent 4b479db commit 1f75d4e

File tree

2 files changed

+56
-18
lines changed

2 files changed

+56
-18
lines changed
 

‎packages/compiler-ssr/__tests__/ssrElement.spec.ts

+33
Original file line numberDiff line numberDiff line change
@@ -337,6 +337,39 @@ describe('ssr: element', () => {
337337
`)
338338
})
339339

340+
test('custom dir with v-text', () => {
341+
expect(getCompiledString(`<div v-xxx v-text="foo" />`))
342+
.toMatchInlineSnapshot(`
343+
"\`<div\${
344+
_ssrRenderAttrs(_ssrGetDirectiveProps(_ctx, _directive_xxx))
345+
}>\${
346+
_ssrInterpolate(_ctx.foo)
347+
}</div>\`"
348+
`)
349+
})
350+
351+
test('custom dir with v-text and normal attrs', () => {
352+
expect(getCompiledString(`<div class="test" v-xxx v-text="foo" />`))
353+
.toMatchInlineSnapshot(`
354+
"\`<div\${
355+
_ssrRenderAttrs(_mergeProps({ class: "test" }, _ssrGetDirectiveProps(_ctx, _directive_xxx)))
356+
}>\${
357+
_ssrInterpolate(_ctx.foo)
358+
}</div>\`"
359+
`)
360+
})
361+
362+
test('mulptiple custom dirs with v-text', () => {
363+
expect(getCompiledString(`<div v-xxx v-yyy v-text="foo" />`))
364+
.toMatchInlineSnapshot(`
365+
"\`<div\${
366+
_ssrRenderAttrs(_mergeProps(_ssrGetDirectiveProps(_ctx, _directive_xxx), _ssrGetDirectiveProps(_ctx, _directive_yyy)))
367+
}>\${
368+
_ssrInterpolate(_ctx.foo)
369+
}</div>\`"
370+
`)
371+
})
372+
340373
test('custom dir with object v-bind', () => {
341374
expect(getCompiledString(`<div v-bind="x" v-xxx />`))
342375
.toMatchInlineSnapshot(`

‎packages/compiler-ssr/src/transforms/ssrTransformElement.ts

+23-18
Original file line numberDiff line numberDiff line change
@@ -28,6 +28,7 @@ import {
2828
createSequenceExpression,
2929
createSimpleExpression,
3030
createTemplateLiteral,
31+
findDir,
3132
hasDynamicKeyVBind,
3233
isStaticArgOf,
3334
isStaticExp,
@@ -164,24 +165,28 @@ export const ssrTransformElement: NodeTransform = (node, context) => {
164165
]
165166
}
166167
} else if (directives.length && !node.children.length) {
167-
const tempId = `_temp${context.temps++}`
168-
propsExp.arguments = [
169-
createAssignmentExpression(
170-
createSimpleExpression(tempId, false),
171-
mergedProps,
172-
),
173-
]
174-
rawChildrenMap.set(
175-
node,
176-
createConditionalExpression(
177-
createSimpleExpression(`"textContent" in ${tempId}`, false),
178-
createCallExpression(context.helper(SSR_INTERPOLATE), [
179-
createSimpleExpression(`${tempId}.textContent`, false),
180-
]),
181-
createSimpleExpression(`${tempId}.innerHTML ?? ''`, false),
182-
false,
183-
),
184-
)
168+
// v-text directive has higher priority than the merged props
169+
const vText = findDir(node, 'text')
170+
if (!vText) {
171+
const tempId = `_temp${context.temps++}`
172+
propsExp.arguments = [
173+
createAssignmentExpression(
174+
createSimpleExpression(tempId, false),
175+
mergedProps,
176+
),
177+
]
178+
rawChildrenMap.set(
179+
node,
180+
createConditionalExpression(
181+
createSimpleExpression(`"textContent" in ${tempId}`, false),
182+
createCallExpression(context.helper(SSR_INTERPOLATE), [
183+
createSimpleExpression(`${tempId}.textContent`, false),
184+
]),
185+
createSimpleExpression(`${tempId}.innerHTML ?? ''`, false),
186+
false,
187+
),
188+
)
189+
}
185190
}
186191

187192
if (needTagForRuntime) {

0 commit comments

Comments
 (0)
Please sign in to comment.