mirror of
https://github.com/nuxt/nuxt.git
synced 2025-01-18 17:35:57 +00:00
refactor(nitro): app template 2-3 normalization (#177)
This commit is contained in:
parent
f91f822ed4
commit
1bbd754f29
@ -5,9 +5,9 @@
|
|||||||
</head>
|
</head>
|
||||||
<body {{ BODY_ATTRS }}>
|
<body {{ BODY_ATTRS }}>
|
||||||
{{ BODY_SCRIPTS_PREPEND }}
|
{{ BODY_SCRIPTS_PREPEND }}
|
||||||
<div id="__nuxt">{{ APP }}</div>
|
{{ APP }}
|
||||||
|
{{ BODY_SCRIPTS }}
|
||||||
<% if (nuxt.options.vite && nuxt.options.dev) { %><script type="module" src="/@vite/client"></script>
|
<% if (nuxt.options.vite && nuxt.options.dev) { %><script type="module" src="/@vite/client"></script>
|
||||||
<script type="module" src="/entry.mjs"></script><% } %>
|
<script type="module" src="/entry.mjs"></script><% } %>
|
||||||
{{ BODY_SCRIPTS }}
|
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
@ -57,6 +57,9 @@ export interface NuxtHooks {
|
|||||||
// 'watch:fileChanged': (builder: Builder, fileName: string) => HookResult
|
// 'watch:fileChanged': (builder: Builder, fileName: string) => HookResult
|
||||||
'builder:watch': (event: WatchEvent, path: string) => HookResult
|
'builder:watch': (event: WatchEvent, path: string) => HookResult
|
||||||
|
|
||||||
|
// @nuxt/nitro
|
||||||
|
'nitro:template': (template: { src: string, contents: string }) => HookResult
|
||||||
|
|
||||||
// @nuxt/cli
|
// @nuxt/cli
|
||||||
'cli:buildError': (error: unknown) => HookResult
|
'cli:buildError': (error: unknown) => HookResult
|
||||||
'generate:cache:ignore': (ignore: string[]) => HookResult
|
'generate:cache:ignore': (ignore: string[]) => HookResult
|
||||||
|
@ -49,8 +49,8 @@ export async function build (nitroContext: NitroContext) {
|
|||||||
const htmlTemplate = { src: htmlSrc, contents: '', dst: '', compiled: '' }
|
const htmlTemplate = { src: htmlSrc, contents: '', dst: '', compiled: '' }
|
||||||
htmlTemplate.dst = htmlTemplate.src.replace(/.html$/, '.js').replace('app.', 'document.')
|
htmlTemplate.dst = htmlTemplate.src.replace(/.html$/, '.js').replace('app.', 'document.')
|
||||||
htmlTemplate.contents = await readFile(htmlTemplate.src, 'utf-8')
|
htmlTemplate.contents = await readFile(htmlTemplate.src, 'utf-8')
|
||||||
htmlTemplate.compiled = 'module.exports = ' + serializeTemplate(htmlTemplate.contents)
|
|
||||||
await nitroContext._internal.hooks.callHook('nitro:template:document', htmlTemplate)
|
await nitroContext._internal.hooks.callHook('nitro:template:document', htmlTemplate)
|
||||||
|
htmlTemplate.compiled = 'module.exports = ' + serializeTemplate(htmlTemplate.contents)
|
||||||
await writeFile(htmlTemplate.dst, htmlTemplate.compiled)
|
await writeFile(htmlTemplate.dst, htmlTemplate.compiled)
|
||||||
|
|
||||||
nitroContext.rollupConfig = getRollupConfig(nitroContext)
|
nitroContext.rollupConfig = getRollupConfig(nitroContext)
|
||||||
|
@ -6,7 +6,6 @@ import { getNitroContext, NitroContext } from './context'
|
|||||||
import { createDevServer } from './server/dev'
|
import { createDevServer } from './server/dev'
|
||||||
import { wpfs } from './utils/wpfs'
|
import { wpfs } from './utils/wpfs'
|
||||||
import { resolveMiddleware } from './server/middleware'
|
import { resolveMiddleware } from './server/middleware'
|
||||||
import { serializeTemplate } from './utils'
|
|
||||||
|
|
||||||
export default function nuxt2CompatModule () {
|
export default function nuxt2CompatModule () {
|
||||||
const { nuxt } = this
|
const { nuxt } = this
|
||||||
@ -34,6 +33,8 @@ export default function nuxt2CompatModule () {
|
|||||||
nitroDevContext._internal.hooks.hook('renderLoading',
|
nitroDevContext._internal.hooks.hook('renderLoading',
|
||||||
(req, res) => nuxt.callHook('server:nuxt:renderLoading', req, res))
|
(req, res) => nuxt.callHook('server:nuxt:renderLoading', req, res))
|
||||||
|
|
||||||
|
nitroContext._internal.hooks.hook('nitro:template', template => nuxt.callHook('nitro:template', template))
|
||||||
|
|
||||||
// Expose process.env.NITRO_PRESET
|
// Expose process.env.NITRO_PRESET
|
||||||
nuxt.options.env.NITRO_PRESET = nitroContext.preset
|
nuxt.options.env.NITRO_PRESET = nitroContext.preset
|
||||||
|
|
||||||
@ -57,7 +58,6 @@ export default function nuxt2CompatModule () {
|
|||||||
if (!htmlTemplate.contents.includes('BODY_SCRIPTS_PREPEND')) {
|
if (!htmlTemplate.contents.includes('BODY_SCRIPTS_PREPEND')) {
|
||||||
const fullTemplate = ['{{ BODY_SCRIPTS_PREPEND }}', '{{ APP }}', '{{ BODY_SCRIPTS }}'].join('\n ')
|
const fullTemplate = ['{{ BODY_SCRIPTS_PREPEND }}', '{{ APP }}', '{{ BODY_SCRIPTS }}'].join('\n ')
|
||||||
htmlTemplate.contents = htmlTemplate.contents.replace('{{ APP }}', fullTemplate)
|
htmlTemplate.contents = htmlTemplate.contents.replace('{{ APP }}', fullTemplate)
|
||||||
htmlTemplate.compiled = 'module.exports = ' + serializeTemplate(htmlTemplate.contents)
|
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -103,9 +103,10 @@ function renderHTML (payload, rendered, ssrContext) {
|
|||||||
meta.htmlAttrs += _meta.htmlAttrs.text()
|
meta.htmlAttrs += _meta.htmlAttrs.text()
|
||||||
meta.headAttrs += _meta.headAttrs.text()
|
meta.headAttrs += _meta.headAttrs.text()
|
||||||
meta.headTags +=
|
meta.headTags +=
|
||||||
_meta.title.text() + _meta.meta.text() +
|
_meta.title.text() + _meta.base.text() +
|
||||||
_meta.link.text() + _meta.style.text() +
|
_meta.meta.text() + _meta.link.text() +
|
||||||
_meta.script.text() + _meta.noscript.text()
|
_meta.style.text() + _meta.script.text() +
|
||||||
|
_meta.noscript.text()
|
||||||
meta.bodyAttrs += _meta.bodyAttrs.text()
|
meta.bodyAttrs += _meta.bodyAttrs.text()
|
||||||
meta.bodyScriptsPrepend =
|
meta.bodyScriptsPrepend =
|
||||||
_meta.meta.text({ pbody: true }) + _meta.link.text({ pbody: true }) +
|
_meta.meta.text({ pbody: true }) + _meta.link.text({ pbody: true }) +
|
||||||
|
@ -1,2 +1,6 @@
|
|||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
export { renderToString } from '@vue/server-renderer'
|
import { renderToString as render } from '@vue/server-renderer'
|
||||||
|
|
||||||
|
export const renderToString: typeof render = (...args) => {
|
||||||
|
return render(...args).then(result => `<div id="__nuxt">${result}</div>`)
|
||||||
|
}
|
||||||
|
@ -21,6 +21,8 @@ export function initNitro (nuxt: Nuxt) {
|
|||||||
// Expose process.env.NITRO_PRESET
|
// Expose process.env.NITRO_PRESET
|
||||||
nuxt.options.env.NITRO_PRESET = nitroContext.preset
|
nuxt.options.env.NITRO_PRESET = nitroContext.preset
|
||||||
|
|
||||||
|
nitroContext._internal.hooks.hook('nitro:template', template => nuxt.callHook('nitro:template', template))
|
||||||
|
|
||||||
// Wait for all modules to be ready
|
// Wait for all modules to be ready
|
||||||
nuxt.hook('modules:done', async () => {
|
nuxt.hook('modules:done', async () => {
|
||||||
// Extend nitro with modules
|
// Extend nitro with modules
|
||||||
|
Loading…
Reference in New Issue
Block a user