mirror of
https://github.com/nuxt/nuxt.git
synced 2025-01-18 09:25:54 +00:00
fix(vite): separate dynamic deps in dev-bundler (#2067)
This commit is contained in:
parent
95978ed14d
commit
a149225e63
@ -1,6 +1,6 @@
|
|||||||
<template>
|
<template>
|
||||||
<div>
|
<div>
|
||||||
<hello-world />
|
<lazy-hello-world />
|
||||||
<nuxt3 />
|
<nuxt3 />
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
@ -1,5 +1,11 @@
|
|||||||
<template>
|
<template>
|
||||||
<div>
|
<div class="hello">
|
||||||
This is HelloWorld component!
|
This is HelloWorld component!
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
<style scoped>
|
||||||
|
.hello {
|
||||||
|
color: red;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
@ -1,5 +1,11 @@
|
|||||||
<template>
|
<template>
|
||||||
<b style="color: #00C58E">
|
<b class="nuxt3">
|
||||||
From Nuxt 3
|
From Nuxt 3
|
||||||
</b>
|
</b>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
<style scoped>
|
||||||
|
.nuxt3 {
|
||||||
|
color: #00C58E;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
import { defineNuxtConfig } from 'nuxt3'
|
import { defineNuxtConfig } from 'nuxt3'
|
||||||
|
|
||||||
export default defineNuxtConfig({
|
export default defineNuxtConfig({
|
||||||
vite: false,
|
|
||||||
components: {
|
components: {
|
||||||
dirs: [
|
dirs: [
|
||||||
'~/components',
|
'~/components',
|
||||||
|
@ -102,9 +102,9 @@ export async function buildServer (ctx: ViteBuildContext) {
|
|||||||
// Build and watch
|
// Build and watch
|
||||||
const _doBuild = async () => {
|
const _doBuild = async () => {
|
||||||
const start = Date.now()
|
const start = Date.now()
|
||||||
const { code, ids } = await bundleRequest({ viteServer }, '/.nuxt/server.js')
|
const { code, chunks } = await bundleRequest({ viteServer }, '/.nuxt/server.js')
|
||||||
// Have CSS in the manifest to prevent FOUC on dev SSR
|
// Have CSS in the manifest to prevent FOUC on dev SSR
|
||||||
await generateDevSSRManifest(ctx, ids.filter(isCSS).map(i => '../' + i.slice(1)))
|
await generateDevSSRManifest(ctx, chunks.filter(i => !i.isDynamic && isCSS(i.id)).map(i => '../' + i.id.slice(1)))
|
||||||
await fse.writeFile(resolve(ctx.nuxt.options.buildDir, 'dist/server/server.mjs'), code, 'utf-8')
|
await fse.writeFile(resolve(ctx.nuxt.options.buildDir, 'dist/server/server.mjs'), code, 'utf-8')
|
||||||
const time = (Date.now() - start)
|
const time = (Date.now() - start)
|
||||||
consola.info(`Server built in ${time}ms`)
|
consola.info(`Server built in ${time}ms`)
|
||||||
|
@ -3,13 +3,15 @@ import { existsSync } from 'fs'
|
|||||||
import { resolve } from 'pathe'
|
import { resolve } from 'pathe'
|
||||||
import * as vite from 'vite'
|
import * as vite from 'vite'
|
||||||
import { ExternalsOptions, isExternal as _isExternal, ExternalsDefaults } from 'externality'
|
import { ExternalsOptions, isExternal as _isExternal, ExternalsDefaults } from 'externality'
|
||||||
import { hashId, uniq } from './utils'
|
import { hashId } from './utils'
|
||||||
|
|
||||||
export interface TransformChunk {
|
export interface TransformChunk {
|
||||||
id: string,
|
id: string,
|
||||||
code: string,
|
code: string,
|
||||||
deps: string[],
|
deps: string[],
|
||||||
parents: string[]
|
parents: string[]
|
||||||
|
dynamicDeps: string[],
|
||||||
|
isDynamic: boolean,
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface SSRTransformResult {
|
export interface SSRTransformResult {
|
||||||
@ -91,22 +93,42 @@ ${res.code || '/* empty */'};
|
|||||||
return { code, deps: res.deps || [], dynamicDeps: res.dynamicDeps || [] }
|
return { code, deps: res.deps || [], dynamicDeps: res.dynamicDeps || [] }
|
||||||
}
|
}
|
||||||
|
|
||||||
async function transformRequestRecursive (opts: TransformOptions, id, parent = '<entry>', chunks: Record<string, TransformChunk> = {}) {
|
function markChunkAsSync (chunk: TransformChunk, chunks: Record<string, TransformChunk>) {
|
||||||
|
if (!chunk.isDynamic) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
chunk.isDynamic = false
|
||||||
|
for (const id of chunk.deps) {
|
||||||
if (chunks[id]) {
|
if (chunks[id]) {
|
||||||
|
markChunkAsSync(chunks[id], chunks)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async function transformRequestRecursive (opts: TransformOptions, id: string, parent = '<entry>', chunks: Record<string, TransformChunk> = {}, isDynamic = false) {
|
||||||
|
if (chunks[id]) {
|
||||||
|
if (!isDynamic) {
|
||||||
|
// chunks that been imported as both dynamic and sync
|
||||||
|
markChunkAsSync(chunks[id], chunks)
|
||||||
|
}
|
||||||
chunks[id].parents.push(parent)
|
chunks[id].parents.push(parent)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
const res = await transformRequest(opts, id)
|
const res = await transformRequest(opts, id)
|
||||||
const deps = uniq([...res.deps, ...res.dynamicDeps])
|
|
||||||
|
|
||||||
chunks[id] = {
|
chunks[id] = <TransformChunk>{
|
||||||
id,
|
id,
|
||||||
code: res.code,
|
code: res.code,
|
||||||
deps,
|
deps: res.deps,
|
||||||
|
dynamicDeps: res.dynamicDeps,
|
||||||
|
isDynamic,
|
||||||
parents: [parent]
|
parents: [parent]
|
||||||
} as TransformChunk
|
}
|
||||||
for (const dep of deps) {
|
for (const dep of res.deps) {
|
||||||
await transformRequestRecursive(opts, dep, id, chunks)
|
await transformRequestRecursive(opts, dep, id, chunks, isDynamic)
|
||||||
|
}
|
||||||
|
for (const dep of res.dynamicDeps) {
|
||||||
|
await transformRequestRecursive(opts, dep, id, chunks, true)
|
||||||
}
|
}
|
||||||
return Object.values(chunks)
|
return Object.values(chunks)
|
||||||
}
|
}
|
||||||
@ -211,6 +233,6 @@ async function __instantiateModule__(url, urlStack) {
|
|||||||
|
|
||||||
return {
|
return {
|
||||||
code,
|
code,
|
||||||
ids: chunks.map(i => i.id)
|
chunks
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -106,10 +106,10 @@ export async function buildServer (ctx: ViteBuildContext) {
|
|||||||
// Build and watch
|
// Build and watch
|
||||||
const _doBuild = async () => {
|
const _doBuild = async () => {
|
||||||
const start = Date.now()
|
const start = Date.now()
|
||||||
const { code, ids } = await bundleRequest({ viteServer }, resolve(ctx.nuxt.options.appDir, 'entry'))
|
const { code, chunks } = await bundleRequest({ viteServer }, resolve(ctx.nuxt.options.appDir, 'entry'))
|
||||||
await fse.writeFile(resolve(ctx.nuxt.options.buildDir, 'dist/server/server.mjs'), code, 'utf-8')
|
await fse.writeFile(resolve(ctx.nuxt.options.buildDir, 'dist/server/server.mjs'), code, 'utf-8')
|
||||||
// Have CSS in the manifest to prevent FOUC on dev SSR
|
// Have CSS in the manifest to prevent FOUC on dev SSR
|
||||||
await writeManifest(ctx, ids.filter(isCSS).map(i => i.slice(1)))
|
await writeManifest(ctx, chunks.filter(i => !i.isDynamic && isCSS(i.id)).map(i => i.id.slice(1)))
|
||||||
const time = (Date.now() - start)
|
const time = (Date.now() - start)
|
||||||
consola.success(`Vite server built in ${time}ms`)
|
consola.success(`Vite server built in ${time}ms`)
|
||||||
await onBuild()
|
await onBuild()
|
||||||
|
Loading…
Reference in New Issue
Block a user