Skip to content

parseResource marks all script chunks as modules #44

Open
@IlyaSemenov

Description

@IlyaSemenov

parseResource always marks all scripts as modules:

export const parseResource = (path: string) => {
const chunk: Omit<ResourceMeta, 'file'> = {}
const extension = path.replace(/\?.*/, '').split('.').pop() || ''
const asType = getAsType(extension)
if (asType) {
chunk.resourceType = asType
if (asType === 'script') {
chunk.module = true
}

This in turn affects normalizeViteManifest which emits all script chunks as having module: true:

export function normalizeViteManifest (manifest: ViteManifest | Manifest): Manifest {
const _manifest: Manifest = {}
for (const file in manifest) {
const chunk = manifest[file]
_manifest[file] = { ...parseResource(chunk.file || file), ...chunk }

Then, renderScripts always emits <script type="module"> preventing legacy browsers from even loading the code:

export function renderScripts (ssrContext: SSRContext, rendererContext: RendererContext): string {
const { scripts } = getRequestDependencies(ssrContext, rendererContext)
return Object.values(scripts).map(resource => renderScriptToString({
type: resource.module ? 'module' : null,

See nuxt/bridge#621 for the actual user-facing issue.

Metadata

Metadata

Assignees

No one assigned

    Labels

    bugSomething isn't working

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions