diff --git a/packages/ref-transform/__tests__/refTransform.spec.ts b/packages/ref-transform/__tests__/refTransform.spec.ts index b4b34737..1b9f3003 100644 --- a/packages/ref-transform/__tests__/refTransform.spec.ts +++ b/packages/ref-transform/__tests__/refTransform.spec.ts @@ -395,4 +395,12 @@ describe('errors', () => { `$computed can only be used as the initializer` ) }) + + test('not transform the prototype attributes', () => { + const { code } = transform(` + const hasOwnProperty = Object.prototype.hasOwnProperty + const hasOwn = (val, key) => hasOwnProperty.call(val, key) + `) + expect(code).not.toMatch('.value') + }) }) diff --git a/packages/ref-transform/src/refTransform.ts b/packages/ref-transform/src/refTransform.ts index 7fae8562..bfed7311 100644 --- a/packages/ref-transform/src/refTransform.ts +++ b/packages/ref-transform/src/refTransform.ts @@ -20,7 +20,7 @@ import { walkFunctionParams } from '@vue/compiler-core' import { parse, ParserPlugin } from '@babel/parser' -import { babelParserDefaultPlugins } from '@vue/shared' +import { babelParserDefaultPlugins, hasOwn } from '@vue/shared' const TO_VAR_SYMBOL = '$' const TO_REF_SYMBOL = '$$' @@ -309,7 +309,7 @@ export function transformAST( parent: Node, parentStack: Node[] ): boolean { - if (id.name in scope) { + if (hasOwn(scope, id.name)) { if (scope[id.name]) { if (isStaticProperty(parent) && parent.shorthand) { // let binding used in a property shorthand