fix(compiler-core): fix multiline member expression check (#2436)
fix #2426
This commit is contained in:
parent
288c764e52
commit
6d2a1cb64d
@ -36,9 +36,13 @@ return function render(_ctx, _cache) {
|
|||||||
return (_openBlock(), _createBlock(\\"input\\", {
|
return (_openBlock(), _createBlock(\\"input\\", {
|
||||||
modelValue:
|
modelValue:
|
||||||
model
|
model
|
||||||
|
.
|
||||||
|
foo
|
||||||
,
|
,
|
||||||
\\"onUpdate:modelValue\\": $event => (
|
\\"onUpdate:modelValue\\": $event => (
|
||||||
model
|
model
|
||||||
|
.
|
||||||
|
foo
|
||||||
= $event)
|
= $event)
|
||||||
}, null, 8 /* PROPS */, [\\"modelValue\\", \\"onUpdate:modelValue\\"]))
|
}, null, 8 /* PROPS */, [\\"modelValue\\", \\"onUpdate:modelValue\\"]))
|
||||||
}
|
}
|
||||||
|
@ -115,8 +115,9 @@ describe('compiler: transform v-model', () => {
|
|||||||
expect(generate(root, { mode: 'module' }).code).toMatchSnapshot()
|
expect(generate(root, { mode: 'module' }).code).toMatchSnapshot()
|
||||||
})
|
})
|
||||||
|
|
||||||
|
// #2426
|
||||||
test('simple expression (with multilines)', () => {
|
test('simple expression (with multilines)', () => {
|
||||||
const root = parseWithVModel('<input v-model="\n model \n" />')
|
const root = parseWithVModel('<input v-model="\n model\n.\nfoo \n" />')
|
||||||
const node = root.children[0] as ElementNode
|
const node = root.children[0] as ElementNode
|
||||||
const props = ((node.codegenNode as VNodeCall).props as ObjectExpression)
|
const props = ((node.codegenNode as VNodeCall).props as ObjectExpression)
|
||||||
.properties
|
.properties
|
||||||
@ -127,7 +128,7 @@ describe('compiler: transform v-model', () => {
|
|||||||
isStatic: true
|
isStatic: true
|
||||||
},
|
},
|
||||||
value: {
|
value: {
|
||||||
content: '\n model \n',
|
content: '\n model\n.\nfoo \n',
|
||||||
isStatic: false
|
isStatic: false
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
@ -141,7 +142,7 @@ describe('compiler: transform v-model', () => {
|
|||||||
children: [
|
children: [
|
||||||
'$event => (',
|
'$event => (',
|
||||||
{
|
{
|
||||||
content: '\n model \n',
|
content: '\n model\n.\nfoo \n',
|
||||||
isStatic: false
|
isStatic: false
|
||||||
},
|
},
|
||||||
' = $event)'
|
' = $event)'
|
||||||
|
@ -56,7 +56,7 @@ const nonIdentifierRE = /^\d|[^\$\w]/
|
|||||||
export const isSimpleIdentifier = (name: string): boolean =>
|
export const isSimpleIdentifier = (name: string): boolean =>
|
||||||
!nonIdentifierRE.test(name)
|
!nonIdentifierRE.test(name)
|
||||||
|
|
||||||
const memberExpRE = /^[A-Za-z_$][\w$]*(?:\.[A-Za-z_$][\w$]*|\[[^\]]+\])*$/
|
const memberExpRE = /^[A-Za-z_$][\w$]*(?:\s*\.\s*[A-Za-z_$][\w$]*|\[[^\]]+\])*$/
|
||||||
export const isMemberExpression = (path: string): boolean => {
|
export const isMemberExpression = (path: string): boolean => {
|
||||||
if (!path) return false
|
if (!path) return false
|
||||||
return memberExpRE.test(path.trim())
|
return memberExpRE.test(path.trim())
|
||||||
|
Loading…
Reference in New Issue
Block a user