From e4f09c1419352c18a60a5930d9526d916d1323d3 Mon Sep 17 00:00:00 2001 From: Evan You Date: Mon, 30 Nov 2020 16:30:36 -0500 Subject: [PATCH] fix(compiler-core/v-on): handle falsy values when caching v-on handlers fix #2605 --- .../__tests__/transforms/vOn.spec.ts | 42 ++++++++++++++++++- packages/compiler-core/src/transforms/vOn.ts | 4 +- 2 files changed, 43 insertions(+), 3 deletions(-) diff --git a/packages/compiler-core/__tests__/transforms/vOn.spec.ts b/packages/compiler-core/__tests__/transforms/vOn.spec.ts index 57408568fbc..85b1b93b7b5 100644 --- a/packages/compiler-core/__tests__/transforms/vOn.spec.ts +++ b/packages/compiler-core/__tests__/transforms/vOn.spec.ts @@ -476,7 +476,47 @@ describe('compiler: transform v-on', () => { index: 1, value: { type: NodeTypes.COMPOUND_EXPRESSION, - children: [`(...args) => (`, { content: `_ctx.foo(...args)` }, `)`] + children: [ + `(...args) => (`, + { content: `_ctx.foo && _ctx.foo(...args)` }, + `)` + ] + } + }) + }) + + test('compound member expression handler', () => { + const { root, node } = parseWithVOn(`
`, { + prefixIdentifiers: true, + cacheHandlers: true + }) + expect(root.cached).toBe(1) + const vnodeCall = node.codegenNode as VNodeCall + // should not treat cached handler as dynamicProp, so no flags + expect(vnodeCall.patchFlag).toBeUndefined() + expect( + (vnodeCall.props as ObjectExpression).properties[0].value + ).toMatchObject({ + type: NodeTypes.JS_CACHE_EXPRESSION, + index: 1, + value: { + type: NodeTypes.COMPOUND_EXPRESSION, + children: [ + `(...args) => (`, + { + children: [ + { content: `_ctx.foo` }, + `.`, + { content: `bar` }, + ` && `, + { content: `_ctx.foo` }, + `.`, + { content: `bar` }, + `(...args)` + ] + }, + `)` + ] } }) }) diff --git a/packages/compiler-core/src/transforms/vOn.ts b/packages/compiler-core/src/transforms/vOn.ts index 02dd9796031..bf51a5f6241 100644 --- a/packages/compiler-core/src/transforms/vOn.ts +++ b/packages/compiler-core/src/transforms/vOn.ts @@ -108,9 +108,9 @@ export const transformOn: DirectiveTransform = ( // avoiding the need to be patched. if (shouldCache && isMemberExp) { if (exp.type === NodeTypes.SIMPLE_EXPRESSION) { - exp.content += `(...args)` + exp.content = `${exp.content} && ${exp.content}(...args)` } else { - exp.children.push(`(...args)`) + exp.children = [...exp.children, ` && `, ...exp.children, `(...args)`] } } }