功能
启用或禁用可选的 Nuxt 功能以解锁新的可能性。
Nuxt 的某些功能是可选的,或者可以根据您的需求禁用。
功能
inlineStyles
在渲染 HTML 时内联样式。目前仅在使用 Vite 时可用。
您还可以传递一个函数,该函数接收 Vue 组件的路径并返回一个布尔值,指示是否内联该组件的样式。
nuxt.config.ts
export default defineNuxtConfig({
features: {
inlineStyles: false // or a function to determine inlining
}
})
noScripts
禁用 Nuxt 脚本和 JS 资源提示的渲染。也可以在 routeRules
中进行细粒度配置。
nuxt.config.ts
export default defineNuxtConfig({
features: {
noScripts: true
}
})
future
还有一个 future
命名空间,用于提前选择加入将在框架的未来(可能是主要)版本中成为默认设置的新功能。
compatibilityVersion
此配置选项在 Nuxt v3.12+ 中可用。请注意,目前,您需要在选择加入 Nuxt 4 行为的每个层中定义兼容性版本。这在 Nuxt 4 发布后将不再需要。
这使您可以提前访问 Nuxt 功能或标志。
将 compatibilityVersion
设置为 4
会更改整个 Nuxt 配置中的默认设置,以选择加入 Nuxt v4 行为,但您可以在测试时细粒度地重新启用 Nuxt v3 行为(请参阅示例)。如果遇到问题,请提交 issue,以便我们在 Nuxt 或生态系统中解决。
export default defineNuxtConfig({
future: {
compatibilityVersion: 4,
},
// To re-enable _all_ Nuxt v3 behaviour, set the following options:
srcDir: '.',
dir: {
app: 'app'
},
experimental: {
scanPageMeta: 'after-resolve',
sharedPrerenderData: false,
compileTemplate: true,
resetAsyncDataToUndefined: true,
templateUtils: true,
relativeWatchPaths: true,
normalizeComponentNames: false
defaults: {
useAsyncData: {
deep: true
}
}
},
features: {
inlineStyles: true
},
unhead: {
renderSSRHeadOptions: {
omitLineBreaks: false
}
}
})
typescriptBundlerResolution
这为 TypeScript 启用了 “Bundler” 模块解析模式,这是 Nuxt 和 Vite 等框架的推荐设置。
当使用带有 exports
的现代库时,它可以提高类型支持。
请参阅 原始 TypeScript pull request。
nuxt.config.ts
export default defineNuxtConfig({
future: {
typescriptBundlerResolution: true
}
})