La propriété build
Nuxt.js nous permet de personnaliser la configuration de webpack afin de build notre application Web comme on l'entend.
analyze
Nuxt.js utilise webpack-bundle-analyzer pour nous permettre de visualiser les bundles et trouver comment les optimiser.
-
Type:
Boolean
ouObject
-
Par défaut:
false
Si c'est un objet, les propriétés disponibles sont visibles ici .
export default {
build: {
analyze: true,
// ou
analyze: {
analyzerMode: 'static'
}
}
}
yarn nuxt build --analyze
ou bien yarn nuxt build -a
pour build notre application et lancer l'analyseur des bundles sur http://localhost:8888 . Si on n'utilise pas yarn
, on peut exécuter la commande avec npx
.corejs
Depuis Nuxt@2.14 , Nuxt.js va automatiquement détecter la version actuelle de
core-js
dans notre projet. On peut bien sûr aussi lui spécifier la version que l'on veut utiliser.
-
Type:
number
|string
(Les valeurs disponibles sont'auto'
,2
et3
) -
Default:
'auto'
babel
Permet de personnaliser la configuration Babel pour le JavaScript et les fichiers Vue.
.babelrc
est ignoré par défaut.
-
Type:
Object
-
Voir les options de
babel-loader
et les options debabel
. -
Par défaut:
{ babelrc: false, cacheDirectory: undefined, presets: ['@nuxt/babel-preset-app'] }
Les cibles par défaut de @nuxt/babel-preset-app sont ie: '9'
dans le build client
, et node: 'current'
dans le build serveur
.
presets
-
Type:
Function
-
Argument:
-
Object
: { isServer: true | false } -
Array
:-
nom du preset
@nuxt/babel-preset-app
-
options
de@nuxt/babel-preset-app
-
nom du preset
-
Note: Les presets configurés dans build.babel.presets
seront appliqués tant au build du client que celui du serveur. La cible sera choisie par Nuxt.js en conséquence (client/serveur). Si on veut configurer le preset différemment, il faut utiliser presets
en tant que fonction:
Nous recommandons très chaudement d'utiliser la configuration par défaut au lieu du code plus bas
export default {
build: {
babel: {
presets({ isServer }, [ preset, options ]) {
// on change directement les options
options.targets = isServer ? ... : ...
options.corejs = ...
// renvoie rien
}
}
}
}
On peut aussi écraser les valeurs par défaut en retournant la liste complète des presets:
export default {
build: {
babel: {
presets({ isServer }, [preset, options]) {
return [
[
preset,
{
buildTarget: isServer ? ... : ...,
...options
}
],
[
// d'autres presets
]
]
}
}
}
}
cache
-
Type:
Boolean
-
Par défaut:
false
- ⚠️ Expérimental
Active le cache de terser-webpack-plugin et de cache-loader
cssSourceMap
-
Type:
boolean
-
Par défaut:
true
pour le développement etfalse
pour la production.
Active le support du CSS Source Map
devMiddleware
-
Type:
Object
Voir webpack-dev-middleware pour les options disponibles.
devtools
-
Type:
boolean
-
Par défaut:
false
Définit le droit d'afficher l'inspection des vue-devtools .
Si cela a déjà été activé grâce au fichier nuxt.config.js
ou autrement, les devtools seront activés, peu importe le flag.
extend
Permet de personnaliser manuellement la configuration de Webpack pour les bundles client et serveur.
-
Type:
Function
extend
est appelé deux fois, une fois pour le bundle du serveur, et une fois pour celui du client. Les arguments de la méthode sont:
- L'objet de configuration Webpack
-
L'objet avec les clés suivantes (tous sont des booléens sauf
loaders
):isDev
,isClient
,isServer
etloaders
.
isClient
et isServer
fournies n'ont rien à voir avec celles présentes dans le context
. Elles ne sont pas dépréciées. Il ne faut en outre pas utiliser process.client
et process.server
ici car ils seront undefined
à ce niveau.export default {
build: {
extend(config, { isClient }) {
// personnalisation de la configuration Webpack seulement pour le bundle client
if (isClient) {
config.devtool = 'source-map'
}
}
}
}
Si on souhaite en savoir davantage sur la configuration Webpack par défaut, il faut aller jeter un coup d'œil au répertoire de Webpack .
Les loaders dans extend
Les loaders
ont la même structure au niveau de l'objet que build.loaders , on peut donc changer les options des loaders
à l'intérieur d'extend
.
export default {
build: {
extend(config, { isClient, loaders: { vue } }) {
// personnalisation de la configuration Webpack seulement pour le bundle client
if (isClient) {
vue.transformAssetUrls.video = ['src', 'poster']
}
}
}
}
extractCSS
Permet le
Common CSS Extraction
en utilisant les directives du packageVue Server Renderer
.
-
Type:
Boolean
ouObject
-
Par défaut:
false
L'usage de extract-css-chunks-webpack-plugin
se fait de manière implicite, en séparant notre CSS dans des fichiers séparés, un par composant en général. Cela permet de mettre en cache notre CSS et notre JavaScript séparément et est sans doute quelque chose à essayer dans le cas où on possède beaucoup de CSS global ou partagé.
Exemple (nuxt.config.js
):
export default {
build: {
extractCSS: true,
// ou
extractCSS: {
ignoreOrder: true
}
}
}
On pourrait souhaiter extraire tout notre CSS dans un seul fichier. Il y a une solution pour cela:
export default {
build: {
extractCSS: true,
optimization: {
splitChunks: {
cacheGroups: {
styles: {
name: 'styles',
test: /\.(css|vue)$/,
chunks: 'all',
enforce: true
}
}
}
}
}
}
filenames
Permet de personnaliser le nom des fichiers des bundles.
-
Type:
Object
-
Par défault:
{ app: ({ isDev, isModern }) => isDev ? `[name]${isModern ? '.modern' : ''}.js` : `[contenthash:7]${isModern ? '.modern' : ''}.js`, chunk: ({ isDev, isModern }) => isDev ? `[name]${isModern ? '.modern' : ''}.js` : `[contenthash:7]${isModern ? '.modern' : ''}.js`, css: ({ isDev }) => isDev ? '[name].css' : 'css/[contenthash:7].css', img: ({ isDev }) => isDev ? '[path][name].[ext]' : 'img/[name].[contenthash:7].[ext]', font: ({ isDev }) => isDev ? '[path][name].[ext]' : 'fonts/[name].[contenthash:7].[ext]', video: ({ isDev }) => isDev ? '[path][name].[ext]' : 'videos/[name].[contenthash:7].[ext]' }
Cet exemple change les noms originaux des fragments en des identifiants numériques:
export default {
build: {
filenames: {
chunk: ({ isDev }) => (isDev ? '[name].js' : '[id].[contenthash].js')
}
}
}
Pour comprendre un peu mieux l'utilisation des manifests
, il faut se référer à la documentation de Webpack .
friendlyErrors
-
Type:
Boolean
-
Par défaut:
true
(Affichage sympa activé)
Active ou désactive les indications claires et précises fournies par FriendlyErrorsWebpackPlugin .
hardSource
-
Type:
Boolean
-
Par défaut:
false
- ⚠️ Expérimental
Active le plugin HardSourceWebpackPlugin pour une mise en cache améliorée.
hotMiddleware
-
Type:
Object
Se référer à webpack-hot-middleware pour les options disponibles.
html.minify
-
Type:
Object
- Par défault:
{
collapseBooleanAttributes: true,
decodeEntities: true,
minifyCSS: true,
minifyJS: true,
processConditionalComments: true,
removeEmptyAttributes: true,
removeRedundantAttributes: true,
trimCustomFragments: true,
useShortDoctype: true
}
Attention: si l'on fait des changements à html.minify
, il ne seront pas fusionnés avec les valeurs par défaut !
La configuration pour le plugin html-minifier est là pour minifier les fichiers HTML créés durant le processus de build (la minification sera appliqueé pour tous les modes).
indicator
Affiche un indicateur de build pour le Hot Module Replacement (HMR) lors du développement. Disponible depuis la
v2.8.0
.
-
Type:
Boolean
-
Par défault:
true
loaders
Permet de personnaliser les options de Nuxt.js par rapport aux loaders intégrés.
-
Type:
Object
- Par défault:
{
file: {},
fontUrl: { limit: 1000 },
imgUrl: { limit: 1000 },
pugPlain: {},
vue: {
transformAssetUrls: {
video: 'src',
source: 'src',
object: 'src',
embed: 'src'
}
},
css: {},
cssModules: {
localIdentName: '[local]_[hash:base64:5]'
},
less: {},
sass: {
indentedSyntax: true
},
scss: {},
stylus: {},
vueStyle: {}
}
Note: en plus de spécifier la configuration d ans un fichier
nuxt.config.js
, cela peut aussi être modifié par build.extend .
loaders.file
Davantage de détails dans les options de file-loader .
loaders.fontUrl and loaders.imgUrl
Davantage de détails dans les options d'url-loader .
loaders.pugPlain
Davantage de détails dans le pug-plain-loader ou les options du compilateur Pug .
loaders.vue
Davantage de détails dans les options de vue-loader .
loaders.css and loaders.cssModules
Davantage de détails dans les options du css-loader .
Note: les CSS modules sont des options pour le loader.
loaders.less
On peut passer des options spécifique à Less au
less-loader
vialoaders.less
. Se référer à la documentation de Less pour toutes les options disponibles.
loaders.sass et loaders.scss
Se référer à la documentation de Node Sass pour toutes les options disponibles de Sass.
Note:
loaders.sass
est utilisé pour la Syntaxe Indentée de Sass .
loaders.vueStyle
Davantage de détails dans les options de vue-style-loader .
optimization
-
Type:
Object
-
Par défault:
{ minimize: true, minimizer: [ // terser-webpack-plugin // optimize-css-assets-webpack-plugin ], splitChunks: { chunks: 'all', automaticNameDelimiter: '.', name: undefined, cacheGroups: {} } }
La valeur par défaut de splitChunks.name
est true
dans le mode dev
ou bien analyze
.
On peut définir minimizer
à un tableau personnalisé de plugins ou définir minimize
à false
pour désactiver tous les minimiseurs. (minimize
est désactivé lors du développement par défaut)
Se référer à la documentation sur l'optimisation de Webpack .
optimizeCSS
-
Type:
Object
ouBoolean
-
Par défault:
-
false
-
{}
lorsque extractCSS est activé
-
Les options du plugin OptimizeCSSAssets.
Se référer à NMFR/optimize-css-assets-webpack-plugin .
parallel
-
Type:
Boolean
-
Par défaut:
false
- ⚠️ Expérimental
Active le thread-loader lors du build de Webpack.
plugins
Ajoute des plugins Webpack
-
Type:
Array
-
Par défault:
[]
import webpack from 'webpack'
import { version } from './package.json'
export default {
build: {
plugins: [
new webpack.DefinePlugin({
'process.VERSION': version
})
]
}
}
postcss
Permet de personnaliser les plugins du PostCSS Loader .
-
Type:
Array
(legacy, écrasera les valeurs par défaut),Object
(recommandé),Function
ouBoolean
Note: Nuxt.js a appliqué PostCSS Preset Env . Par défaut, cela active les fonctionnalités du niveau 2 et l'Autoprefixer , on peut utiliser build.postcss.preset
pour le configurer.
-
Par défault:
nuxt.config.js
{ plugins: { 'postcss-import': {}, 'postcss-url': {}, 'postcss-preset-env': this.preset, 'cssnano': { preset: 'default' } // désactivé lors du développement }, order: 'presetEnvAndCssnanoLast', preset: { stage: 2 } }
Les paramètres personnalisés du plugin seront fusionnés avec les valeurs par défaut des plugins (à moins qu'on n'utilise un Array
au lieu d'un Object
).
export default {
build: {
postcss: {
plugins: {
// désactive `postcss-url`
'postcss-url': false,
// ajouter quelques plugins
'postcss-nested': {},
'postcss-responsive-type': {},
'postcss-hexrgba': {}
},
preset: {
autoprefixer: {
grid: true
}
}
}
}
}
Si la configuration postCSS est un Object
, order
peut être utilisé pour définir l'ordre du plugin:
-
Type:
Array
(nom des plugins rangés),String
(rangé selon le nom du preset),Function
-
Par défaut:
cssnanoLast
(cssnano
est en dernier)
export default {
build: {
postcss: {
// nom du preset
order: 'cssnanoLast',
// nom des plugins rangés
order: ['postcss-import', 'postcss-preset-env', 'cssnano']
// fonction pour déterminer l'ordre du plugin
order: (names, presets) => presets.cssnanoLast(names)
}
}
}
plugins postcss et nuxt-tailwindcss
Si l'on souhaite appliquer un plugin postCSS (ex: postcss-pxtorem
) sur une configuration de nuxt-tailwindcss
, on doit changer l'ordre et charger tailwindcss
en premier.
Cette configuration n'a pas d'impact sur nuxt-purgecss
.
import { join } from 'path'
export default {
// ...
build: {
postcss: {
plugins: {
tailwindcss: join(__dirname, 'tailwind.config.js'),
'postcss-pxtorem': {
propList: ['*', '!border*']
}
}
}
}
}
profile
-
Type:
Boolean
-
Par défault: activé avec l'argument
--profile
dans la ligne de commande
Active le profiler dans WebpackBar
publicPath
Nuxt.js nous permet de téléverser les fichiers présents dans notre répertoire
dist
jusqu'à notre CDN pour des performances maximales, il suffit de définir l'URL de notre CDN danspublicPath
.
-
Type:
String
-
Default:
'/_nuxt/'
export default {
build: {
publicPath: 'https://cdn.nuxtjs.org'
}
}
Ensuite, lorsque on lance nuxt build
, il suffit de téléverser le contenu du répertoire .nuxt/dist/client
dans notre CDN et voilà !
quiet
Supprime la majeure partie de la journalisation des builds
-
Type:
Boolean
-
Par défault: Activé lorsque l'environment détecté par std-env est égal à
CI
outest
.
splitChunks
-
Type:
Object
-
Par défault:
nuxt.config.js
export default { build: { splitChunks: { layouts: false, pages: true, commons: true } } }
Si séparation de code pour layout
, pages
et commons
(bibliothèques communes: vue|vue-loader|vue-router|vuex...).
ssr
Crée un bundle Webpack spécial pour le rendu côté serveur.
-
Type:
Boolean
-
Par défault:
true
pour le mode universel etfalse
pour notre soirée SPA
Cette option est automatiquement définie en se basant sur la valeur de mode
si rien n'est fourni.
standalone
Dépendances du groupe de serveurs en ligne (avancé)
-
Type:
Boolean
-
Default:
false
Ce mode regroupe des node_modules
qui sont normalement conservés en tant qu'externes dans la construction du serveur (plus d'informations ).
nuxt.config
, middleware du serveur et répertoire statique) ne sont pas regroupées. Cette fonctionnalité désactive uniquement l'utilisation de webpack-externes for server-bundle.yarn nuxt build --standalone
pour activer ce mode sur la ligne de commande. (Si vous n'utilisez pas yarn
, vous pouvez exécuter la commande avec npx
.)styleResources
-
Type:
Object
-
Par défault:
{}
Ceci est utile lorsque on a besoin d'injecter certains variables ou mixins à l'intérieur de nos pages sans avoir besoin de les importer à chaque fois.
Nuxt.js utilise https://github.com/yenshih/style-resources-loader pour réussir ce comportement.
Il y a besoin de spécifier un schéma/un chemin si on veut la partager pour les pre-processors nuls et ajoute des: less
, sass
, scss
ou stylus
.
On ne peut pas utiliser d'alias de chemin (~
ou @
), on aura besoin d'utiliser des chemins relatifs ou absolus.
{
build: {
styleResources: {
scss: './assets/variables.scss',
less: './assets/*.less',
// sass: ...,
// scss: ...
options: {
// Voir https://github.com/yenshih/style-resources-loader#options
// Sauf la propriété `patterns`
}
}
}
}
templates
Nuxt.js nous permet d'utiliser nos propres templates qui seront render basés sur les modules .
-
Type:
Array
export default {
build: {
templates: [
{
src: '~/modules/support/plugin.js', // `src` peut être relatif ou absolu
dst: 'support.js', // `dst` est relative au project `.nuxt` dir
options: {
// Les options sont passés aux templates grâce à la clé `options`
live_chat: false
}
}
]
}
}
Les templates sont render en utilisant lodash.template
, cela permet d'en savoir plus sur les otages et leur mentalité/adresse psk c'est sincère.
terser
-
Type:
Object
ouBoolean
- Par défault:
{
parallel: true,
cache: false,
sourceMap: false,
extractComments: {
filename: 'LICENSES'
},
terserOptions: {
output: {
comments: /^\**!|@preserve|@license|@cc_on/
}
}
}
Options du plugin Terser. Il suffit de mettre un false
pour désactiver le plugin.
L'activation de sourceMap
laissera le commentaire de liaison //# sourceMappingURL
à la fin de chaque fichier de sortie si webpack config.devtool
est défini sur source-map
.
Voir webpack-contrib/terser-webpack-plugin .
transpile
-
Type:
Array<String | RegExp | Function>
-
Par défault:
[]
Si on veut transpiler certaines dépendances spécifiques avec Babel, on peut les ajouter dans build.transpile
. Chaque item transpilé peut être un nom de package, une chaîne de caractères ou un objet regex pour matcher le nom du fichier avec la dépendance que l'on souhaite.
Depuis v2.9.0
, on peut aussi utiliser une fonction pour rendre la transpilation conditionnelle, la fonction recevra un objet ({ isDev, isServer, isClient, isModern, isLegacy }
):
{
build: {
transpile: [({ isLegacy }) => isLegacy && 'ky']
}
}
Dans cet exemple, ky
sera transpilé par Babel si Nuxt n'est pas en mode moderne .
vueLoader
Note: Cette configuration a été enlevée depuis Nuxt 2.0, il faut maintenant utiliser
build.loaders.vue
à la place.
-
Type:
Object
-
Par défault:
nuxt.config.js
{ productionMode: !this.options.dev, transformAssetUrls: { video: 'src', source: 'src', object: 'src', embed: 'src' } }
Pour spécifier les options Vue Loader Options .
watch
On peut fournir nos propres fichiers personnalisés à surveiller avant de régénérer après des modifications. Cette fonctionnalité est surtout utile à utiliser avec modules .
-
Type:
Array<String>
export default {
build: {
watch: ['~/.nuxt/support.js']
}
}
followSymlinks
Par défaut, le build process ne scan pas les fichiers avec des liens symboliques. Ce booléen les inclut, et nous permet donc d'avoir des liens symboliques à l'intérieur des répertoires tels que
pages
par exemple.
-
Type:
Boolean
export default {
build: {
followSymlinks: true
}
}