Skip to content

Commit

Permalink
fix: set scripts imported by HTML moduleSideEffects=true (vitejs#18411)
Browse files Browse the repository at this point in the history
  • Loading branch information
sapphi-red authored Oct 26, 2024
1 parent 409fa5c commit 2ebe4b4
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 9 deletions.
19 changes: 18 additions & 1 deletion packages/vite/src/node/plugins/html.ts
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,8 @@ export function htmlInlineProxyPlugin(config: ResolvedConfig): Plugin {
const url = file.replace(normalizePath(config.root), '')
const result = htmlProxyMap.get(config)!.get(url)?.[index]
if (result) {
return result
// set moduleSideEffects to keep the module even if `treeshake.moduleSideEffects=false` is set
return { ...result, moduleSideEffects: true }
} else {
throw new Error(`No matching HTML proxy module found from ${id}`)
}
Expand Down Expand Up @@ -426,6 +427,7 @@ export function buildHtmlPlugin(config: ResolvedConfig): Plugin {
return url
}

const setModuleSideEffectPromises: Promise<void>[] = []
await traverseHtml(html, id, (node) => {
if (!nodeIsElement(node)) {
return
Expand All @@ -452,6 +454,19 @@ export function buildHtmlPlugin(config: ResolvedConfig): Plugin {
if (isModule) {
inlineModuleIndex++
if (url && !isExcludedUrl(url) && !isPublicFile) {
setModuleSideEffectPromises.push(
this.resolve(url, id)
.then((resolved) => {
if (!resolved) {
return Promise.reject()
}
return this.load(resolved)
})
.then((mod) => {
// set this to keep the module even if `treeshake.moduleSideEffects=false` is set
mod.moduleSideEffects = true
}),
)
// <script type="module" src="..."/>
// add it as an import
js += `\nimport ${JSON.stringify(url)}`
Expand Down Expand Up @@ -687,6 +702,8 @@ export function buildHtmlPlugin(config: ResolvedConfig): Plugin {
js = `import "${modulePreloadPolyfillId}";\n${js}`
}

await Promise.all(setModuleSideEffectPromises)

// Force rollup to keep this module from being shared between other entry points.
// If the resulting chunk is empty, it will be removed in generateBundle.
return { code: js, moduleSideEffects: 'no-treeshake' }
Expand Down
9 changes: 1 addition & 8 deletions packages/vite/src/node/plugins/resolve.ts
Original file line number Diff line number Diff line change
Expand Up @@ -348,14 +348,7 @@ export function resolvePlugin(
res = ensureVersionQuery(res, id, options, ssr, depsOptimizer)
debug?.(`[relative] ${colors.cyan(id)} -> ${colors.dim(res)}`)

// If this isn't a script imported from a .html file, include side effects
// hints so the non-used code is properly tree-shaken during build time.
if (
!options.idOnly &&
!options.scan &&
options.isBuild &&
!importer?.endsWith('.html')
) {
if (!options.idOnly && !options.scan && options.isBuild) {
const resPkg = findNearestPackageData(
path.dirname(res),
options.packageCache,
Expand Down

0 comments on commit 2ebe4b4

Please sign in to comment.