feat: minify head inline scripts

pull/478/head
Evan You 3 years ago
parent a355b20f90
commit e61db62a1c

@ -3,6 +3,14 @@ export default {
title: 'VitePress', title: 'VitePress',
description: 'Vite & Vue powered static site generator.', description: 'Vite & Vue powered static site generator.',
head: [
[
'script',
{},
'(() => { const afsefe = window.foo;\n console.log(afsefe);})()'
]
],
themeConfig: { themeConfig: {
repo: 'vuejs/vitepress', repo: 'vuejs/vitepress',
docsDir: 'docs', docsDir: 'docs',

@ -2,7 +2,7 @@ import path from 'path'
import fs from 'fs-extra' import fs from 'fs-extra'
import { SiteConfig, resolveSiteDataByRoute } from '../config' import { SiteConfig, resolveSiteDataByRoute } from '../config'
import { HeadConfig } from '../shared' import { HeadConfig } from '../shared'
import { normalizePath } from 'vite' import { normalizePath, transformWithEsbuild } from 'vite'
import { RollupOutput, OutputChunk, OutputAsset } from 'rollup' import { RollupOutput, OutputChunk, OutputAsset } from 'rollup'
import { slash } from '../utils/slash' import { slash } from '../utils/slash'
import escape from 'escape-html' import escape from 'escape-html'
@ -121,7 +121,7 @@ export async function renderPage(
${stylesheetLink} ${stylesheetLink}
${preloadLinksString} ${preloadLinksString}
${prefetchLinkString} ${prefetchLinkString}
${renderHead(head)} ${await renderHead(head)}
</head> </head>
<body> <body>
<div id="app">${content}</div> <div id="app">${content}</div>
@ -165,17 +165,24 @@ function resolvePageImports(
] ]
} }
function renderHead(head: HeadConfig[]) { function renderHead(head: HeadConfig[]): Promise<string> {
return head return Promise.all(
.map(([tag, attrs = {}, innerHTML = '']) => { head.map(async ([tag, attrs = {}, innerHTML = '']) => {
const openTag = `<${tag}${renderAttrs(attrs)}>` const openTag = `<${tag}${renderAttrs(attrs)}>`
if (tag !== 'link' && tag !== 'meta') { if (tag !== 'link' && tag !== 'meta') {
if (tag === 'script') {
innerHTML = (
await transformWithEsbuild(innerHTML, 'inline-script.js', {
minify: true
})
).code.trim()
}
return `${openTag}${innerHTML}</${tag}>` return `${openTag}${innerHTML}</${tag}>`
} else { } else {
return openTag return openTag
} }
}) })
.join('\n ') ).then((tags) => tags.join('\n '))
} }
function renderAttrs(attrs: Record<string, string>): string { function renderAttrs(attrs: Record<string, string>): string {

Loading…
Cancel
Save