Migration depuis NuxtJS
Voici quelques concepts clés et stratégies de migration pour vous aider à démarrer. Utilisez le reste de nos documents et notre communauté sur Discord pour continuer !
Ce guide fait référence à Nuxt 2, et non au plus récent Nuxt 3. Bien que certains des concepts soient similaires, Nuxt 3 est une version plus récente du framework et peut nécessiter des stratégies différentes pour certaines parties de votre migration.
Principales similitudes entre Nuxt et Astro
Titre de la section Principales similitudes entre Nuxt et AstroNuxt et Astro partagent certaines similitudes qui vous aideront à migrer votre projet :
- Les projets Astro peuvent également être de type SSG ou SSR avec prérendu au niveau de la page (EN).
- Astro utilise le routage basé sur des fichiers et permet à des pages spécialement nommées de créer des routes dynamiques.
- Astro est basé sur les composants, et votre structure de balisage sera similaire avant et après votre migration.
- Astro possède une intégration officielle pour utiliser les composants Vue.
- Astro prend en charge l’installation de paquets NPM, y compris les bibliothèques Vue. Vous pourrez peut-être conserver certains ou tous vos composants et dépendances Vue existants.
Principales différences entre Nuxt et Astro
Titre de la section Principales différences entre Nuxt et AstroLorsque vous reconstruisez votre site Nuxt dans Astro, vous remarquerez quelques différences importantes :
-
Nuxt est un SPA (application monopage) basé sur Vue. Les sites Astro sont des applications multipages créées à l’aide de composants
.astro
, mais ils peuvent également prendre en charge React, Preact, Vue.js, Svelte, SolidJS, AlpineJS, Lit et des modèles HTML brut. -
Routage des pages : Nuxt utilise
vue-router
pour le routage SPA etvue-meta
pour gérer<head>
. Dans Astro, vous créerez des routes distinctes pour vos pages HTML et vous contrôlerez le contenu de la balise<head>
directement dans votre page ou dans un composant de mise en page. -
Axé sur le contenu : Astro a été conçu pour présenter votre contenu et pour vous permettre d’opter pour l’interactivité uniquement en cas de besoin. Une application Nuxt existante peut être conçue pour une interactivité élevée côté client. Astro possède des fonctionnalités intégrées pour travailler avec votre contenu, telles que la génération de pages, mais peut nécessiter les techniques avancées d’Astro pour inclure des éléments plus difficiles à reproduire en utilisant des composants
.astro
, comme les tableaux de bord.
Convertir votre projet NuxtJS
Titre de la section Convertir votre projet NuxtJSChaque migration de projet sera différente, mais vous effectuerez certaines actions courantes lors de la conversion de Nuxt vers Astro.
Créer un nouveau projet Astro
Titre de la section Créer un nouveau projet AstroUtilisez la commande create astro
de votre gestionnaire de paquets pour lancer l’assistant CLI d’Astro ou choisissez un thème de communauté dans la vitrine de thèmes Astro.
Vous pouvez utiliser un argument --template
avec la commande create astro
pour démarrer un nouveau projet Astro avec l’un de nos démarreurs officiels (par exemple docs
, blog
, portfolio
). Vous pouvez également démarrer un nouveau projet à partir de n’importe quel dépôt Astro existant sur GitHub.
Ensuite, copiez les fichiers existants de votre projet Nuxt vers votre nouveau projet Astro dans un dossier séparé en dehors de src
.
Consultez https://astro.new pour la liste complète des modèles de démarrage officiels et des liens pour ouvrir un nouveau projet dans StackBlitz, CodeSandbox ou Gitpod.
Installer des intégrations (facultatif)
Titre de la section Installer des intégrations (facultatif)Vous trouverez peut-être cela utile d’installer certaines des intégrations facultatives d’Astro lors de la conversion de votre projet Nuxt en Astro :
-
@astrojs/vue : pour réutiliser certains de vos composants Vue orientés UI dans votre nouveau site Astro ou pour continuer à coder des composants Vue.
-
@astrojs/mdx : pour importer des fichiers MDX existants de votre projet Nuxt ou pour utiliser MDX dans votre nouveau site Astro.
Placer votre code source dans src
Titre de la section Placer votre code source dans src-
Déplacez les contenus du dossier
static/
de Nuxt danspublic/
.Astro utilise le répertoire
public/
pour les ressources statiques. Ce dernier est semblable au dossierstatic/
de Nuxt. -
Copiez ou déplacez les autres fichiers et dossiers de Nuxt (par exemple,
pages
,layouts
etc.) dans le dossiersrc/
d’Astro.Comme Nuxt, le dossier
src/pages/
d’Astro est un dossier spécial utilisé pour le routage basé sur des fichiers. Tous les autres dossiers sont facultatifs et vous pouvez organiser le contenu de votre dossiersrc/
comme vous le souhaitez. D’autres dossiers courants dans les projets Astro incluentsrc/layouts/
,src/components
,src/styles
,src/scripts
.
Convertir les pages SFC de Vue en fichiers .astro
Titre de la section Convertir les pages SFC de Vue en fichiers .astroVoici quelques conseils pour convertir un composant Nuxt .vue
en un composant .astro
:
-
Utilisez le
<template>
de la fonction du composant NuxtJS existant comme base pour votre modèle HTML. -
Remplacez toute syntaxe Nuxt ou Vue par une syntaxe Astro ou par des normes web HTML. Ceci comprend
<NuxtLink>
,:class
,{{variable}}
etv-if
, par exemple. -
Déplacez le JavaScript présent dans
<script>
dans une « barrière de code » (---
). Convertissez les propriétés de récupération de données de votre composant en JavaScript exécuté côté serveur - consultez la récupération de données, de Nuxt vers Astro. -
Utilisez
Astro.props
pour accéder à toutes les props supplémentaires précédemment transmises à votre composant Vue. -
Décidez si les composants importés doivent également être convertis en syntaxe Astro. Avec l’intégration officielle installée, vous pouvez utiliser les composants Vue existants dans votre fichier Astro. Mais vous souhaiterez peut-être les convertir en composants
.astro
, surtout s’ils n’ont pas besoin d’être interactifs !
Voir un exemple d’une application Nuxt convertie étape par étape.
Comparaison : Vue vs Astro
Titre de la section Comparaison : Vue vs AstroComparez le composant Nuxt suivant et un composant Astro correspondant :
Migrer les fichiers de mise en page
Titre de la section Migrer les fichiers de mise en pageVous trouverez peut-être cela utile de commencer par convertir vos mises en page et modèles Nuxt en composants Astro de mise en page.
Chaque page Astro nécessite explicitement la présence des balises <html>
, <head>
et <body>
. Votre fichier layout.vue
et vos modèles Nuxt ne les incluront pas.
Notez le modèle HTML standard et l’accès direct à <head>
:
Vous souhaiterez peut-être également réutiliser le code de la propriété head
de votre page Nuxt pour inclure des métadonnées de site supplémentaires. Notez qu’Astro n’utilise ni vue-meta
ni la propriété head
d’un composant, mais crée à la place directement <head>
. Vous pouvez importer et utiliser des composants, même dans <head>
, pour séparer et organiser le contenu de votre page.
Migrer les pages et les articles
Titre de la section Migrer les pages et les articlesDans NuxtJS, vos pages se trouvent dans /pages
. Dans Astro, les contenus de vos pages doivent résider dans src/pages
ou src/content
.
Pages Vue
Titre de la section Pages VueVos pages Nuxt Vue (.vue
) existantes devront être converties de fichiers Vue en pages .astro
. Vous ne pouvez pas utiliser un fichier de page Vue existant dans Astro.
Ces pages .astro
doivent être placées dans src/pages/
et les routes des pages seront générées automatiquement en fonction de leur chemin de fichier.
Nommage du chemin de fichier dynamique
Titre de la section Nommage du chemin de fichier dynamiqueDans Nuxt, vos pages dynamiques utilisent un trait de soulignement pour représenter une propriété de page dynamique qui est ensuite transmise à la génération de page :
Répertoirepages/
Répertoirepokemon/
- _name.vue
- index.vue
- nuxt.config.js
Avec Astro, modifiez le nom de fichier du chemin dynamique commençant par un trait de soulignement (par exemple _name.vue
) pour qu’il soit entouré d’une paire de crochets (par exemple [name].astro
) :
Répertoiresrc/
Répertoirepages/
Répertoirepokemon/
- [name].astro
- index.astro
- astro.config.mjs
Pages Markdown et MDX
Titre de la section Pages Markdown et MDXAstro dispose d’une prise en charge intégrée pour Markdown et d’une intégration facultative pour les fichiers MDX. Vous pouvez réutiliser tous les fichiers Markdown et MDX existants, mais ils peuvent nécessiter quelques ajustements dans leur frontmatter, comme l’ajout de la propriété spéciale layout
d’Astro.
Vous n’aurez plus besoin de créer manuellement des pages pour chaque route générée par Markdown ni d’utiliser un paquet externe comme @nuxt/content
. Ces fichiers peuvent être placés dans src/pages/
pour profiter du routage automatique basé sur les fichiers.
Lorsqu’ils font partie d’une collection de contenu, les fichiers Markdown et MDX vivront dans des dossiers à l’intérieur de src/content/
et vous générez ces pages dynamiquement.
Migrer les tests
Titre de la section Migrer les testsComme Astro génère du HTML brut, il est possible d’écrire des tests de bout en bout en utilisant la sortie de l’étape de construction. Tous les tests de bout en bout écrits précédemment peuvent fonctionner immédiatement si vous avez réussi à faire correspondre le balisage de votre site Nuxt. Les bibliothèques de tests telles que Jest et Vue Testing Library peuvent être importées et utilisées dans Astro pour tester vos composants Vue.
Voir le guide de test d’Astro pour en savoir plus.
Référence : Convertir la syntaxe NuxtJS en syntaxe Astro
Titre de la section Référence : Convertir la syntaxe NuxtJS en syntaxe AstroLes variables locales, de Nuxt à Astro
Titre de la section Les variables locales, de Nuxt à AstroPour utiliser des variables locales dans le HTML d’un composant Astro, remplacez les deux ensembles d’accolades par un seul ensemble d’accolades :
La transmission de propriété, de Nuxt à Astro
Titre de la section La transmission de propriété, de Nuxt à AstroPour lier un attribut ou une propriété de composant dans un composant Astro, modifiez cette syntaxe comme suit :
Les liens, de Nuxt à Astro
Titre de la section Les liens, de Nuxt à AstroConvertissez tous les composants <NuxtLink to="">
de Nuxt en balises HTML <a href="">
.
Astro n’utilise aucun composant spécial pour les liens, bien que vous puissiez créer votre propre composant <Link>
. Vous pouvez ensuite importer et utiliser ce <Link>
comme vous le feriez pour n’importe quel autre composant.
Les importations, de Nuxt à Astro
Titre de la section Les importations, de Nuxt à AstroSi nécessaire, mettez à jour toutes les importations de fichiers pour référencer exactement les chemins de fichiers relatifs. Cela peut être fait en utilisant des alias d’importation ou en écrivant un chemin relatif dans son intégralité.
La génération dynamique de pages, de Nuxt à Astro
Titre de la section La génération dynamique de pages, de Nuxt à AstroDans Nuxt, pour générer une page dynamique vous devez soit :
- Utiliser le mode de rendu côté serveur (SSR).
- Utiliser la fonction
generate
dansnuxt.config.js
pour définir toutes les routes statiques possibles.
Dans Astro, vous avez également deux choix :
- Utiliser le mode de rendu côté serveur (EN).
- Exportez une fonction
getStaticPaths()
dans le frontmatter d’une page Astro pour indiquer au framework les routes statiques à générer dynamiquement.
Convertir la fonction generate
de Nuxt en une fonction getStaticPaths
dans Astro.
Titre de la section Convertir la fonction generate de Nuxt en une fonction getStaticPaths dans Astro.Pour générer plusieurs pages, remplacez la fonction pour créer des routes dans votre fichier nuxt.config.js
en ajoutant getStaticPaths()
directement dans une page de routage dynamique :
La récupération de données, de Nuxt à Astro
Titre de la section La récupération de données, de Nuxt à AstroNuxt propose deux méthodes pour récupérer les données côté serveur :
Dans Astro, récupérez les données à l’intérieur de la barrière de code de votre page.
Migrez les éléments suivants :
Vers une barrière de code sans fonction enveloppante :
Les styles, de Nuxt à Astro
Titre de la section Les styles, de Nuxt à AstroNuxt utilise le style des composants de Vue pour générer le style d’une page.
De même, dans Astro, vous pouvez insérer un élément <style>
dans le modèle de votre page pour limiter la portée des styles au composant.
Les styles globaux
Titre de la section Les styles globauxLes balises <style>
limitent la portée des styles (scoped
) par défaut dans Astro. Pour rendre une balise <style>
globale, marquez-la avec l’attribut is:global
:
La prise en charge de préprocesseurs
Titre de la section La prise en charge de préprocesseursAstro prend en charge les préprocesseurs CSS les plus populaires en les installant en tant que dépendance de développement. Par exemple, pour utiliser SCSS :
Après cela, vous pourrez utiliser des styles .scss
ou .sass
sans apporter de modifications à vos styles de composants Vue.
En savoir plus sur les styles dans Astro.
Les plugins d’image de Nuxt vers Astro
Titre de la section Les plugins d’image de Nuxt vers AstroConvertissez tous les composants <nuxt-img/>
ou <nuxt-picture/>
de Nuxt en composant d’image propre à Astro dans les fichiers .astro
ou .mdx
ou en code HTML standard avec la balise <img>
ou la balise <picture>
selon le cas dans vos composants Vue.
Le composant <Image />
d’Astro fonctionne uniquement dans les fichiers .astro
et .mdx
. Consultez la liste complète de ses attributs de composants et notez que plusieurs différeront des attributs de Nuxt.
Dans les composants Vue (.vue
) au sein de votre application Astro, utilisez la syntaxe d’image JSX standard (<img />
). Astro n’optimisera pas ces images, mais vous pouvez installer et utiliser des paquets NPM pour plus de flexibilité.
Vous pouvez en apprendre davantage sur l’utilisation d’images dans Astro dans le guide Images.
Exemple guidé : Voir les étapes !
Titre de la section Exemple guidé : Voir les étapes !Voici un exemple de récupération de données Pokédex dans Nuxt convertie en Astro.
pages/index.vue
récupère et affiche une liste des 151 premiers Pokémon en utilisant la PokéAPI REST.
Voici comment recréer cela dans src/pages/index.astro
, en remplaçant asyncData()
par fetch()
.
-
Identifiez les balises
<template>
et<style>
dans le fichier SFC de Vue. -
Créez
src/pages/index.astro
Utilisez les balises
<template>
et<style>
de fichier SFC de Nuxt. Convertissez n’importe quelle syntaxe Nuxt ou Vue en syntaxe Astro.Remarquez que :
-
<template>
est supprimé -
<style>
n’a plus d’attributscoped
-
v-for
devient.map
. -
:attr="val"
devientattr={val}
-
<NuxtLink>
devient<a>
. -
Le fragment
<> </>
n’est pas nécessaire dans les modèles Astro.
-
-
Ajoutez les importations, les props et le JavaScript nécessaires
Remarquez que :
- La fonction
asyncData
n’est plus nécessaire. Les données de l’API sont récupérées directement dans la barrière de code. - Un composant
<Layout>
est importé et enveloppe le modèle de page.- Notre méthode
head()
de Nuxt est transmise au composant<Layout>
, qui est transmis à l’élément<title>
en tant que propriété.
- Notre méthode
- La fonction
Ressources communautaires
Titre de la section Ressources communautaires- Article de blog : De Nuxt à Astro - reconstruire avec Astro (en)
- Article de blog : Migration d’application de Nuxt 2 vers Astro 3 – de la configuration à la production (en)