Composants Nuxt

Nuxt.js arrive avec quelques composants importants, ceux-ci nous seront utiles pour construire notre application. Les composants sont disponibles de manière globale, ce qui veut dire que nous n'avons pas besoin de les importer pour les utiliser.


Dans les paragraphes suivants, chacun de ces composants sera expliqué.

Le composant Nuxt

Le composant <Nuxt> nous permet d'afficher les composants page. Basiquement, le composant est remplacé par les pages qui concordent avec la route montrée. Ainsi, il est important d'ajouter le composant <Nuxt> à nos layouts.

layouts/default.vue
<template>
  <div>
    <div>Ma barre de navigation</div>
    <Nuxt />
    <div>Mon pied de page</div>
  </div>
</template>
Le composant <Nuxt> ne peut être utilisé que dans les layouts .

Le composant <Nuxt> peut prendre la propriété nuxt-child-key, cette dernière sera passée à <RouterView> afin que les transitions dans les pages dynamiques fonctionnent correctement.

Il y a 2 façons de gérer la propriété key de <RouterView>:

  1. Utiliser la propriété nuxt-child-key sur notre composant <Nuxt>
layouts/default.vue
<template>
  <div>
    <Nuxt :nuxt-child-key="uneKey" />
  </div>
</template>
  1. Ajouter l'option key dans les composants page en tant que string ou function
export default {
  key(route) {
    return route.fullPath
  }
}

Le composant NuxtChild

Ce composant est utilisé pour afficher les composants enfants dans une route imbriquée.

Exemple:

-| pages/
---| parent/
------| child.vue
---| parent.vue

Cette arborescence de fichiers va générer les chemins suivants :

;[
  {
    path: '/parent',
    component: '~/pages/parent.vue',
    name: 'parent',
    children: [
      {
        path: 'child',
        component: '~/pages/parent/child.vue',
        name: 'parent-child'
      }
    ]
  }
]

Pour afficher le composant child.vue, il faut insérer le composant <NuxtChild> à l'intérieur de pages/parent.vue:

pages/parent.vue
<template>
  <div>
    <h1>Je suis la view parent</h1>
    <NuxtChild :foobar="123" />
  </div>
</template>

keep-alive

Les composants <Nuxt> et <NuxtChild/> acceptent tous les deux keep-alive et keep-alive-props.

Pour en apprendre davantage sur keep-alive et keep-alive-props, se référer à la documentation de Vue .
layouts/default.vue
<template>
  <div>
    <Nuxt keep-alive :keep-alive-props="{ exclude: ['modal'] }" />
  </div>
</template>

<!-- le code du haut sera converti dans le code suivant -->
<div>
  <keep-alive :exclude="['modal']">
    <RouterView />
  </keep-alive>
</div>
pages/parent.vue
<template>
  <div>
    <NuxtChild keep-alive :keep-alive-props="{ exclude: ['modal'] }" />
  </div>
</template>

<!-- le code du haut sera converti dans le code suivant -->
<div>
  <keep-alive :exclude="['modal']">
    <RouterView />
  </keep-alive>
</div>

Les composants <NuxtChild> peuvent aussi recevoir des propriétés comme n'importe quel composant standard de Vue.

<template>
  <div>
    <NuxtChild :key="$route.params.id" />
  </div>
</template>

Pour voir un exemple, on peut regarder celui sur les routes imbriquées .

Pour naviguer entre les pages de notre application, il faut utiliser le composant <NuxtLink>. Ce composant est inclus dans Nuxt.js et nous n'avons donc pas besoin de l'importer comme un composant standard. Son fonctionnement est le même qu'une balise HTML <a> a l'exception qu'au lieu d'utiliser un href="/about" il faut utiliser to="/about". Si nous avons déjà utilisé vue-router par le passé, nous pouvons voir <NuxtLink> comme un équivalent à <RouterLink>.

Un simple lien vers la page index.vue dans notre répertoire pages:

<template>
  <NuxtLink to="/">Page d'accueil</NuxtLink>
</template>

Le composant <NuxtLink> doit être utilisé pour tous les liens internes. Ce qui veut dire que tous les liens à l'intérieur de notre site doivent utiliser <NuxtLink>. La balise <a> doit être utilisée pour les liens externes (les sites web qui ne font pas partie de notre application).

<template>
  <div>
    <h1>Page d'accueil</h1>
    <nuxt-link to="/about">
      À propos (lien interne à l'application Nuxt)
    </nuxt-link>
    <a href="https://nuxtjs.org">Lien externe vers une autre page</a>
  </div>
</template>
Si nous voulons en savoir plus sur RouterLink, se référer à la documentation du Routeur Vue .
<NuxtLink> utilise le préfétching intelligent par défaut.

Nuxt.js fait du prefetching intelligent, il détecte si un lien est visible (soit dans le viewport, soit lors d'un défilement) et il prefetch le JavaScript pour ces pages pour qu'elles soient prêtes quand l'utilisateur clique sur le lien. Nuxt.js charge la ressource seulement quand le navigateur n'est pas occupé. Le prefetching n'a pas non plus lieu si l'utilisateur est hors-ligne ou qu'il est en connexion 2G.

Désactiver le prefetching pour des liens spécifiques

Cependant, si notre page est lourde en JavaScript ou que nous avons beaucoup de pages différentes qui se retrouveraient à charger de nombreux scripts tiers, nous pouvons désactiver le prefetching sur certains de ces liens. Pour cela, nous pouvons utiliser la propriété no-prefetch. Depuis Nuxt.js v2.10.0, nous pouvons aussi définir la propriété prefetch à false.

<NuxtLink to="/about" no-prefetch>Page à propos non pré-fetchée</NuxtLink>
<NuxtLink to="/about" :prefetch="false">Page à propos non pré-fetchée</NuxtLink>

Désactiver le prefetching de manière globale

Pour désactiver le prefetching sur tous les liens, il faut passer prefetchLinks à false:

nuxt.config.js
export default {
  router: {
    prefetchLinks: false
  }
}

Depuis Nuxt.js v2.10.0, si nous avons passé prefetchLinks à false mais que nous souhaitons cependant prefetch un lien particulier, nous pouvons utiliser la propriété prefetch:

<NuxtLink to="/about" prefetch>Page à propos pré-fetchée</NuxtLink>

linkActiveClass

linkActiveClass marche de la même façon que la classe sur des liens actifs de vue-router. Si nous souhaitons montrer quels liens sont actifs, la seule chose que nous avons besoin de faire est de créer un peu de CSS pour la classe nuxt-link-active.

.nuxt-link-active {
  color: red;
}
Ce CSS peut être ajouté au composant de navigation, dans une page spécifique, dans un layout ou dans le fichier main.css.

Si nous souhaitons changer le nom de cette classe par autre chose, nous pouvons modifier linkActiveClass dans la propriété router à l'intérieur du fichier nuxt.config.js.

export default {
  router: {
    linkActiveClass: 'mon-super-lien-actif'
  }
}
Cette option est donnée directement à la propriété linkActiveClass du vue-router, plus d'informations ici .

linkExactActiveClass

linkExactActiveClass marche exactement de la même façon que linkActiveClass dans le cas d'une correspondance exacte de la route.

.nuxt-link-exact-active {
  color: green;
}

La configuration dans le fichier nuxt.config.js se fait de la même façon.

nuxt.config.js
export default {
  router: {
    linkExactActiveClass: 'mon-lien-exact-actif'
  }
}

linkPrefetchedClass

linkPrefetchedClass va nous permettre d'ajouter des styles pour tous les liens qui ont été prefetch. C'est pratique pour tester tous les liens qui ont été prefetch après avoir modifié un comportement. linkPrefetchedClass est désactivé par défaut. Si nous souhaitons l'activer, il faut ajouter la propriété dans le fichier nuxt.config.js.

nuxt.config.js
export default {
  router: {
    linkPrefetchedClass: 'lien-de-nuxt-prefetched'
  }
}

Il suffit par la suite d'ajouter les styles pour cette classe.

.nuxt-link-prefetched {
  color: orangeRed;
}
Comme nous avons pu le voir avec lien-de-nuxt-prefetched, le nom de la classe est totalement arbitraire.

Le composant côté-client seulement

L'usage de ce composant force un composant a être render uniquement du côté client. Pour importer un composant seulement sur le client, il faut l'encapsuler dans un client-only.

pages/example.vue
<template>
  <div>
    <sidebar />
    <client-only placeholder="Chargement...">
      <!-- ce composant sera render seulement du côté client -->
      <comments></comments>
    </client-only>
  </div>
</template>

Utiliser un élément de substitution jusqu'à ce que le contenu du <client-only /> ne soit monté sur le client.

pages/example.vue
<template>
  <div>
    <sidebar />
    <client-only>
      <!-- ce composant sera render seulement du côté client -->
      <comments></comments>

      <!-- indicateur de chargement, render du côté serveur -->
      <comments-placeholder slot="placeholder"></comments-placeholder>
    </client-only>
  </div>
</template>
Depuis Nuxt.js > v2.9.0, il faut utiliser <client-only> au lieu de <no-ssr>.
Editer cette page sur GitHub Mise à jour le Mon, July 12, 2021