fix(compiler-core): v-on inline async function expression handler (#4569)
fix #4568
This commit is contained in:
parent
141a5e188c
commit
fc968d607b
@ -563,6 +563,58 @@ describe('compiler: transform v-on', () => {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
test('inline async arrow function expression handler', () => {
|
||||||
|
const { root, node } = parseWithVOn(
|
||||||
|
`<div v-on:click="async () => await foo()" />`,
|
||||||
|
{
|
||||||
|
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: 0,
|
||||||
|
value: {
|
||||||
|
type: NodeTypes.COMPOUND_EXPRESSION,
|
||||||
|
children: [`async () => await `, { content: `_ctx.foo` }, `()`]
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
test('inline async function expression handler', () => {
|
||||||
|
const { root, node } = parseWithVOn(
|
||||||
|
`<div v-on:click="async function () { await foo() } " />`,
|
||||||
|
{
|
||||||
|
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: 0,
|
||||||
|
value: {
|
||||||
|
type: NodeTypes.COMPOUND_EXPRESSION,
|
||||||
|
children: [
|
||||||
|
`async function () { await `,
|
||||||
|
{ content: `_ctx.foo` },
|
||||||
|
`() } `
|
||||||
|
]
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
test('inline statement handler', () => {
|
test('inline statement handler', () => {
|
||||||
const { root, node } = parseWithVOn(`<div v-on:click="foo++" />`, {
|
const { root, node } = parseWithVOn(`<div v-on:click="foo++" />`, {
|
||||||
prefixIdentifiers: true,
|
prefixIdentifiers: true,
|
||||||
|
@ -16,7 +16,8 @@ import { validateBrowserExpression } from '../validateExpression'
|
|||||||
import { hasScopeRef, isMemberExpression } from '../utils'
|
import { hasScopeRef, isMemberExpression } from '../utils'
|
||||||
import { TO_HANDLER_KEY } from '../runtimeHelpers'
|
import { TO_HANDLER_KEY } from '../runtimeHelpers'
|
||||||
|
|
||||||
const fnExpRE = /^\s*([\w$_]+|\([^)]*?\))\s*=>|^\s*function(?:\s+[\w$]+)?\s*\(/
|
const fnExpRE =
|
||||||
|
/^\s*([\w$_]+|(async\s*)?\([^)]*?\))\s*=>|^\s*(async\s+)?function(?:\s+[\w$]+)?\s*\(/
|
||||||
|
|
||||||
export interface VOnDirectiveNode extends DirectiveNode {
|
export interface VOnDirectiveNode extends DirectiveNode {
|
||||||
// v-on without arg is handled directly in ./transformElements.ts due to it affecting
|
// v-on without arg is handled directly in ./transformElements.ts due to it affecting
|
||||||
|
Loading…
Reference in New Issue
Block a user