The injectFilter()
hook allows you to control where and what tags Vike injects in the HTML, most notably preload tags.
If you merely want to change the position of scripts, you can use the injectScriptsAt
setting instead.
Vite also injects preload tags, see Vite > Config > build.modulePreload
.
Examples
Usage
injectFilter()
is called only in production: it has no effect in development. (Because, in development, the dependency graph is lazily discovered and therefore not fully known upon rendering HTML.)
⚠️ injectFilter()
is a beta feature. (Which means breaking changes may occur during any minor version update.)
// /renderer/+onRenderHtml.ts
export { onRenderHtml }
import type { InjectFilterEntry } from 'vike/types'
async function onRenderHtml ( pageContext ) {
// ...
const documentHtml = escapeInject `<!DOCTYPE html>
<html>
<body>
<div id="page-view">${ stream }</div>
</body>
</html>`
const injectFilter = ( assets : InjectFilterEntry []) : void => {
assets. forEach ( asset => {
if (
// We don't touch entry assets (recommended)
asset.isEntry ||
// We don't touch JavaScript preloading (recommended)
asset.assetType === 'script'
) {
return
}
// Preload images
if (asset.assetType === 'image' ) {
asset.inject = 'HTML_BEGIN'
}
// Don't preload fonts
if (asset.assetType === 'font' ) {
asset.inject = false
}
// Preload videos
if (asset.mediaType?. startsWith ( 'video' )) {
asset.inject = 'HTML_END'
}
})
}
return { documentHtml, injectFilter }
}
type InjectFilterEntry = {
inject : false | 'HTML_BEGIN' | 'HTML_END' // Whether and where to inject
src : string // Asset's URL
assetType : "image" | "script" | "font" | "style" | "audio" | "video" | "document" |
"fetch" | "track" | "worker" | "embed" | "object" | null
mediaType : string // MIME type
isEntry : boolean // true ⇒ <script> or <link rel="stylesheet" type="text/css">
// false ⇒ preload tag, e.g. <link rel="preload" as="font">
}
See also