La propriété hooks
Les hooks sont des écouteurs aux événements de Nuxt qui sont généralement utilisés dans les modules de Nuxt, mais aussi disponibles dans le fichier nuxt.config.js.
- 
Type: 
Object 
import fs from 'fs'
import path from 'path'
export default {
  hooks: {
    build: {
      done(builder) {
        const extraFilePath = path.join(
          builder.nuxt.options.buildDir,
          'fichier-supplementaire'
        )
        fs.writeFileSync(extraFilePath, 'Quelque chose de spécial')
      }
    }
  }
}
 Le fonctionnement des hooks suit un modèle de nommage avec des : (ex: build:done). Pour des raisons de simplicité de configuration, on peut les structurer de manière hiérarchique pour ses propres hooks en utilisant un objet (cf. code juste au dessus). Se référencer au fonctionnement interne de Nuxt  pour davantage d'informations.
Liste des hooks
Exemples
Rediriger au router.base lorsque l'on n'est pas sur root 
Imaginons que l'on souhaite servir les pages sur /portal au lieu de /.
C'est peut être un cas particulier, mais le but d'un router.base dans nuxt.config.js est de permettre à un serveur Web de servir une application Nuxt lorsque son point d'entrée n'est pas le domaine principal.
Ceci dit, lorsque l'on est en développement, aller sur localhost, lorsque router.base n'est défini à / retournera une 404. Pour prévenir cela, on peut configurer un hook.
La redirection n'est peut-être pas le meilleur cas d'usage pour une application Web en production, mais cela permettra de pratiquer les hooks.
Pour commencer, on peut changer le router.base  dans le fichier nuxt.config.js:
import hooks from './hooks'
export default {
  router: {
    base: '/portal'
  }
  hooks: hooks(this)
}
 Ensuite, nous allons créer quelques nouveaux fichiers:
- 
hooks/index.js, module des hookshooks/index.jsimport render from './render' export default nuxtConfig => ({ render: render(nuxtConfig) }) - 
hooks/render.js, render du hookhooks/render.jsimport redirectRootToPortal from './route-redirect-portal' export default nuxtConfig => { const router = Reflect.has(nuxtConfig, 'router') ? nuxtConfig.router : {} const base = Reflect.has(router, 'base') ? router.base : '/portal' return { /** * 'render:setupMiddleware' * {@link node_modules/nuxt/lib/core/renderer.js} */ setupMiddleware(app) { app.use('/', redirectRootToPortal(base)) } } } - 
hooks/route-redirect-portal.js, le middleware en questionhooks/route-redirect-portal.js/** * Hook de middleware de Nuxt pour rediriger de `/` à `/portal` (ou toute autre valeur attribuée à `router.base` dans `nuxt.config.js`) * * Doit avoir la même version que `connect` * {@link node_modules/connect/package.json} */ import parseurl from 'parseurl' /** * On branche le middleware pour gérer les redirections au contexte principal de l'application Web. * * La documentation de Nuxt manque d'explications sur l'usage des hooks. * Ceci est un exemple de router afin d'aider à l'expliquer. * * On peut regarder d'autres implémentations en tant qu'inspiration: * - https://github.com/nuxt/nuxt/blob/2.x-dev/examples/with-cookies/plugins/cookies.js * - https://github.com/yyx990803/launch-editor/blob/master/packages/launch-editor-middleware/index.js * * [http_class_http_clientrequest]: https://nodejs.org/api/http.html#http_class_http_clientrequest * [http_class_http_serverresponse]: https://nodejs.org/api/http.html#http_class_http_serverresponse * * @param {http.ClientRequest} req objet de la requête du client interne de Node.js [http_class_http_clientrequest] * @param {http.ServerResponse} res Réponse interne de Node.js [http_class_http_serverresponse] * @param {Function} next callback du middleware */ export default desiredContextRoot => function projectHooksRouteRedirectPortal(req, res, next) { const desiredContextRootRegExp = new RegExp(`^${desiredContextRoot}`) const _parsedUrl = Reflect.has(req, '_parsedUrl') ? req._parsedUrl : null const url = _parsedUrl !== null ? _parsedUrl : parseurl(req) const startsWithDesired = desiredContextRootRegExp.test(url.pathname) const isNotProperContextRoot = desiredContextRoot !== url.pathname if (isNotProperContextRoot && startsWithDesired === false) { const pathname = url.pathname === null ? '' : url.pathname const search = url.search === null ? '' : url.search const Location = desiredContextRoot + pathname + search res.writeHead(302, { Location }) res.end() } next() } 
Ainsi, lorsqu'un collègue accédera accidentellement à / en développement, Nuxt le redirigera automatiquement vers /portal.
 
        N3-rd
       
 
        Adrien Zaganelli
       
 
        Mag
       
 
        Stefan Huber
       
 
        Olga Bulat
       
 
        Maciek Palmowski
       
 
        Sébastien Chopin
       
 
        Daniel Roe
       
 
        Clément Ollivier
       
 
        Paiva
       
 
        Florian Reuschel
       
 
        Rishi Raj Jain
       
 
        Savas Vedova
       
 
        Steven Soekha
       
 
        Vinícius Alves
       
 
        Kareem Dabbeet
       
 
        Valentín Costa
       
 
        Ryan Skinner
       
 
        Alex Hirzel
       
 
        Ajeet Chaulagain
       
 
        René Eschke
       
 
        Nico Devs
       
 
        Muhammad
       
 
        Nazaré da Piedade
       
 
        Naoki Hamada
       
 
        Tom
       
 
        Yann Aufray
       
 
        Anthony Chu
       
 
        Nuzhat Minhaz
       
 
        Lucas Portet
       
 
        Richard Schloss
       
 
        bpy
       
 
        Antony Konstantinidis
       
 
        Hibariya
       
 
        Jose Seabra
       
 
        Eze
       
 
        Florian LEFEBVRE
       
 
        Lucas Recoaro
       
 
        Julien SEIXAS
       
 
        Hugo
       
 
        Sylvain Marroufin
       
 
        Spencer Cooley
       
 
        Piotr Zatorski
       
 
        Vladimir Semyonov
       
 
        Harry Allen
       
 
        kazuya kawaguchi
       
 
        Unai Mengual
       
 
        Hyunseung
       
 
        Alexandre Chopin
       
 
        pooya parsa
       
 
        Nick Medrano
       
 
        Mosaab Emam
       
 
        Ilja
       
 
        Heitor Ramon Ribeiro
       
 
        Nero
       
 
        Yoon Han