From 5a3ccfd9143700c7ca82d2911fe592d0658c5393 Mon Sep 17 00:00:00 2001 From: Evan You Date: Thu, 22 Jul 2021 12:04:46 -0400 Subject: [PATCH] feat(compiler-sfc): avoid exposing imports not used in template close #3183 --- .../__snapshots__/compileScript.spec.ts.snap | 16 +++++++++++++++ .../__tests__/compileScript.spec.ts | 19 ++++++++++++++++++ packages/compiler-sfc/src/compileScript.ts | 20 ++++++++++++++++--- 3 files changed, 52 insertions(+), 3 deletions(-) diff --git a/packages/compiler-sfc/__tests__/__snapshots__/compileScript.spec.ts.snap b/packages/compiler-sfc/__tests__/__snapshots__/compileScript.spec.ts.snap index fde572c8..cc44a7ab 100644 --- a/packages/compiler-sfc/__tests__/__snapshots__/compileScript.spec.ts.snap +++ b/packages/compiler-sfc/__tests__/__snapshots__/compileScript.spec.ts.snap @@ -204,6 +204,22 @@ return { x } }" `; +exports[`SFC compile + + `) + assertCode(content) + // FooBaz: used as PascalCase component + // FooQux: used as kebab-case component + // vMyDir: used as directive v-my-dir + // x: used in interpolation + expect(content).toMatch(`return { fooBar, FooBaz, FooQux, vMyDir, x }`) + }) }) describe('inlineTemplate mode', () => { diff --git a/packages/compiler-sfc/src/compileScript.ts b/packages/compiler-sfc/src/compileScript.ts index 432d977f..82b84528 100644 --- a/packages/compiler-sfc/src/compileScript.ts +++ b/packages/compiler-sfc/src/compileScript.ts @@ -12,7 +12,11 @@ import { TextRange } from './parse' import { parse as _parse, ParserOptions, ParserPlugin } from '@babel/parser' -import { babelParserDefaultPlugins, generateCodeFrame } from '@vue/shared' +import { + babelParserDefaultPlugins, + generateCodeFrame, + hyphenate +} from '@vue/shared' import { Node, Declaration, @@ -105,6 +109,7 @@ interface ImportBinding { source: string rangeNode: Node isFromSetup: boolean + isUsedInTemplate: boolean } interface VariableBinding { @@ -312,12 +317,21 @@ export function compileScript( if (source === 'vue' && imported) { userImportAlias[imported] = local } + + let isUsedInTemplate = true + if (sfc.template && !sfc.template.src) { + isUsedInTemplate = new RegExp( + `\\b(?:${local}|${hyphenate(local)})\\b` + ).test(sfc.template.content) + } + userImports[local] = { isType, imported: imported || 'default', source, rangeNode, - isFromSetup + isFromSetup, + isUsedInTemplate } } @@ -1279,7 +1293,7 @@ export function compileScript( // return bindings from setup const allBindings: Record = { ...setupBindings } for (const key in userImports) { - if (!userImports[key].isType) { + if (!userImports[key].isType && userImports[key].isUsedInTemplate) { allBindings[key] = true } }