diff --git a/packages/compiler-core/__tests__/transforms/vFor.spec.ts b/packages/compiler-core/__tests__/transforms/vFor.spec.ts index b677ca58..c22b364a 100644 --- a/packages/compiler-core/__tests__/transforms/vFor.spec.ts +++ b/packages/compiler-core/__tests__/transforms/vFor.spec.ts @@ -638,6 +638,26 @@ describe('compiler: v-for', () => { }) }) }) + + test('template v-for key no prefixing on attribute key', () => { + const { + node: { codegenNode } + } = parseWithForTransform( + 'test', + { prefixIdentifiers: true } + ) + const innerBlock = codegenNode.children.arguments[1].returns + expect(innerBlock).toMatchObject({ + type: NodeTypes.VNODE_CALL, + tag: FRAGMENT, + props: createObjectMatcher({ + key: { + type: NodeTypes.SIMPLE_EXPRESSION, + content: 'key' + } + }) + }) + }) }) describe('codegen', () => { diff --git a/packages/compiler-core/src/transforms/vFor.ts b/packages/compiler-core/src/transforms/vFor.ts index c6d444ed..f1d739dc 100644 --- a/packages/compiler-core/src/transforms/vFor.ts +++ b/packages/compiler-core/src/transforms/vFor.ts @@ -68,7 +68,12 @@ export const transformFor = createStructuralDirectiveTransform( : keyProp.exp!) const keyProperty = keyProp ? createObjectProperty(`key`, keyExp!) : null - if (!__BROWSER__ && context.prefixIdentifiers && keyProperty) { + if ( + !__BROWSER__ && + context.prefixIdentifiers && + keyProperty && + keyProp!.type !== NodeTypes.ATTRIBUTE + ) { // #2085 process :key expression needs to be processed in order for it // to behave consistently for and . // In the case of ``, the node is discarded and never